当前位置:编程学习 > C/C++ >>

IplImage和CBitmap转化

  在写mfc程序时如果用到opencv,肯定会用到这两个之间的转化。在网上找了好多,几乎都一样,我的情况稍微特殊,找了半天也没合适的,MD,一气之下,自己跟踪进去CvvImage::DrawToHDC,

  void IplImage2CBitmap(Iplimage* ipg_src)

  {

  CBitmap* m_pBitmap=new CBitmap;

  if (ipg_src->depth==IPL_DEPTH_8U)

  {

  uchar buffer[sizeof(BITMAPINFOHEADER) + 1024];

  BITMAPINFO* bmi = (BITMAPINFO*)buffer;

  int bmp_w = ipg_src->width, bmp_h = ipg_src->height;

  //FillBitmapInfo( bmi, bmp_w, bmp_h, Bpp(), pImage->origin );

  int width=bmp_w;

  int height=bmp_h;

  int bpp=ipg_src ? (ipg_src->depth & 255)*ipg_src->nChannels : 0;

  int origin=ipg_src->origin;

  HBITMAP hBitmap;

  BITMAPINFOHEADER* bmih = &(bmi->bmiHeader);

  memset( bmih, 0, sizeof(*bmih));

  bmih->biSize = sizeof(BITMAPINFOHEADER);

  bmih->biWidth = width;

  bmih->biHeight = origin ? abs(height) : -abs(height);

  bmih->biPlanes = 1;

  bmih->biBitCount = (unsigned short)bpp;

  bmih->biCompression = BI_RGB;

  if( bpp == 8 )

  {

  RGBQUAD* palette = bmi->bmiColors;

  int i;

  for( i = 0; i < 256; i++ )

  {

  palette[i].rgbBlue = palette[i].rgbGreen = palette[i].rgbRed = (BYTE)i;

  palette[i].rgbReserved = 0;

  }

  }

  }

  以上代码改装自opencv。到了这个时候就可以

  HBITMAP hbmp=CreateDIBitmap(pdc->GetSafeHdc(),bmih,CBM_INIT,ipg_src->imageData,bmi,DIB_RGB_COLORS);

  这里千万万千要注意的是第一个参数,一定是要将图片显示的设备的句柄,null表示内存。

  最后:m_pBitmap->Attach(hBitmap);完事大吉,当然如果加一个

  if(m_pBitmap->m_hObject!=NULL)

  {

  m_pBitmap->Detach();

  }更好。

  opencv里面是用的是 ::StretchDIBits(设备句柄,……),如果用pdc->StretchBlt()的话是无法显示的,至于为什么,由于水平有限!

  网上的只是参考,一定要有自己的思考。写一些自己理解的转化,虽然也是抄的,但加了自己的东西。

  CBitmap m_bitmap;

  HBITMAP h_bmp;

  h_bmp=m_bitmap.m_hObject;   CBitmap ==>HBITMAP

  m_bitmap=CBitmap::FromHandle(h_bmp);     HBITMAP==>CBitmap

  我曾试着把IplImage直接转化为CBitmap就是用网上的这段代码,可在显示的时候却没成功,也不知道转化是否成功。下面是代码

  IplImage ->CBitmap , Cbitmap ->IplImage

  CDC *pdc = this ->GetDC() ;

  IplImage *img = cvCreateImage( cvSize( 100,100 ) , 8 , 3 );

  CBitmap m_bitmap ;

  m_bitmap.CreateCompatibleBitmap( pdc , 100 ,100 ) ;

  CDC memdc ;

  memdc.CreateCompatibleDC( pdc ) ;

  CBitmap *pold = memdc .SelectObject( &m_bitmap) ;

  CvvImage cvimg ;

  Rect rect(0 , 0 , 100,100 ) ;

  cvimg.CopyOf( img , -1 ) ;

  cvimg.DrawToHDC( memdc.m_hDC , &rect ) ;

  ReleaseDC( pdc) ;

  IplImage *tempimg = cvCloneImage( img ) ;

  m_bitmap.GetBitmapBits( img ->widthStep * img ->height , img ->imageData) ;

  我曾试着把m_bitmap显示出来以验证是否转化成功,用了这样的函数

  memdc.StretchBlt(0,0,rect.Width(),rect.Height(),&memdc,0,0,w,h,SRCCOPY);

  可是没有奏效!至今还不明!

补充:软件开发 , C语言 ,
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,