打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
OpenCV中IplImage 与 Gdiplus 中Bitmap之间的相互转换

Gdiplus::Bitmap转 IplImage

// pIplImage 需要外部释放 Mosesyuan
void CGeneral::BitmapToIplImage(Bitmap* pBitmap, IplImage* &pIplImg)
{
if (!pBitmap)
{
return;
}
if(pIplImg)
{
cvReleaseImage(&pIplImg);
pIplImg = NULL;
}
BitmapData bmpData;
Rect rect(0,0,pBitmap->GetWidth(),pBitmap->GetHeight());
pBitmap->LockBits(&rect, ImageLockModeRead, PixelFormat24bppRGB, &bmpData);
IplImage* tempImg = cvCreateImage(cvSize(pBitmap->GetWidth(), pBitmap->GetHeight()), IPL_DEPTH_8U, 3);
BYTE* temp = (bmpData.Stride>0)?((BYTE*)bmpData.Scan0):((BYTE*)bmpData.Scan0+bmpData.Stride*(bmpData.Height-1));
memcpy(tempImg->imageData, temp, abs(bmpData.Stride)*bmpData.Height);
pBitmap->UnlockBits(&bmpData);
pIplImg = tempImg;
//判断Top-Down or Bottom-Up

if (bmpData.Stride<0)

cvFlip(pIplImg, pIplImg);
}
OpenCV中 IplImage 转 Gdiplus::Bitmap

// pBitmap 同样需要外部释放!!

void CGeneral::IplImageToBitmap(IplImage* pIplImg, Bitmap* &pBitmap)
{
if(!pIplImg)
return;

BITMAPINFOHEADER bmih;
memset(&bmih, 0, sizeof(BITMAPINFOHEADER));
bmih.biSize = sizeof(BITMAPINFOHEADER);
bmih.biWidth = pIplImg->width;
bmih.biHeight = pIplImg->height;
bmih.biPlanes = 1;
bmih.biBitCount = pIplImg->depth*pIplImg->nChannels;
bmih.biSizeImage = pIplImg->imageSize;

BYTE* pData=new BYTE[bmih.biSizeImage];
memcpy(pData, pIplImg->imageDataOrigin, pIplImg->imageSize);

if (pBitmap)
{
delete pBitmap;
pBitmap = NULL;
}
pBitmap = Gdiplus::Bitmap::FromBITMAPINFO((BITMAPINFO*)&bmih, pData);

}

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
如何使用GDI或者GDI+的函数对IplImage进行图像处理?
【C#学习笔记】图片像素操作
GDI 入门(C#高速处理版本)
一个菜鸟的图像处理入门
C#数字图像处理的3种方法
C#图片处理常见方法性能比较
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服