OpenCV IplImage 와 GDI + Bitmap 의 상호 전환
인터넷 에서 이 두 가지 형식 을 검색 하면 메모리 유출 이 있 는 버 전 (예 를 들 어 http://blog.csdn.net/jtujtujtu/article/details/3734722) 따라서 메모리 유출 이 없 는 버 전 을 제공 하여 참고 하 시기 바 랍 니 다.
[주의] GDI + 의 FromBITM APINFO 함 수 를 사용 하면 메모리 가 유출 됩 니 다!
IplImage* Bitmap2IplImage(Bitmap* pBitmap)
{
if (!pBitmap)
return NULL;
int w = pBitmap->GetWidth();
int h = pBitmap->GetHeight();
BitmapData bmpData;
Rect rect(0,0,w,h);
pBitmap->LockBits(&rect, ImageLockModeRead, PixelFormat24bppRGB, &bmpData);
BYTE* temp = (bmpData.Stride>0) ? ((BYTE*)bmpData.Scan0) : ((BYTE*)bmpData.Scan0 + bmpData.Stride*(h-1));
IplImage* pIplImg = cvCreateImage(cvSize(w, h), IPL_DEPTH_8U, 3);
if (!pIplImg)
{
pBitmap->UnlockBits(&bmpData);
return NULL;
}
memcpy(pIplImg->imageData, temp, abs(bmpData.Stride)*bmpData.Height);
pBitmap->UnlockBits(&bmpData);
// Top-Down or Bottom-Up
if (bmpData.Stride<0)
cvFlip(pIplImg, pIplImg);
return pIplImg;
}
// pBitmap
Bitmap* IplImage2Bitmap(IplImage* pIplImg)
{
if(!pIplImg)
return NULL;
Bitmap *pBitmap = new Bitmap(pIplImg->width, pIplImg->height, PixelFormat24bppRGB);
if (!pBitmap)
return NULL;
BitmapData bmpData;
Rect rect(0, 0, pIplImg->width, pIplImg->height);
pBitmap->LockBits(&rect, ImageLockModeWrite, PixelFormat24bppRGB, &bmpData);
BYTE *pByte = (BYTE*)bmpData.Scan0;
if (pIplImg->widthStep == bmpData.Stride) //likely
memcpy(bmpData.Scan0, pIplImg->imageDataOrigin, pIplImg->imageSize);
pBitmap->UnlockBits(&bmpData);
return pBitmap;
}
다음으로 이동:http://www.leewei.org/?p=1009
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
cacheasBitmap 연구true으로 설정하면 Flash가 실행될 때 객체의 내부 비트맵 표현이 캐시됩니다.이 캐시는 복잡한 벡터 내용을 포함하는 디스플레이 대상의 성능을 향상시킬 수 있습니다. 캐시된 비트맵이 있는 표시 대상의 모든 벡터 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.