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语言 ,