IplImage * BmpTOIpl(int width,int height,unsigned char *pBuffer)
data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" data:image/s3,"s3://crabby-images/8c6cf/8c6cf4ffdd445e63c151976879f2592b65c8c63d" alt="" {
IPlImage *image =cvCreateImage(cvSize(width,height),8,1);
image->imageData=pBuffer;
return image;
}
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
CDibPtr IplToDib(IplImage *image)
data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" data:image/s3,"s3://crabby-images/8c6cf/8c6cf4ffdd445e63c151976879f2592b65c8c63d" alt="" {
CDibPtr m_ptrBitmaps;
CSize ImageSize;
ImageSize.cx=image->width;
ImageSize.cy=image->height;
m_ptrBitmaps.Create(ImageSize, 8, CDib::TopDown, CDib::Monochrome);
(unsigned char*) m_ptrBitmaps->GetPixels()=image->ImageData;
return m_ptrBitmaps;
} IplImage* hBitmap2Ipl(HBITMAP hBmp)
data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" data:image/s3,"s3://crabby-images/8c6cf/8c6cf4ffdd445e63c151976879f2592b65c8c63d" alt="" {
BITMAP bmp;
data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
::GetObject(hBmp,sizeof(BITMAP),&bmp);
data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
int nChannels = bmp.bmBitsPixel == 1 ? 1 : bmp.bmBitsPixel/8 ;
int depth = bmp.bmBitsPixel == 1 ? IPL_DEPTH_1U : IPL_DEPTH_8U;
data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
IplImage* img = cvCreateImageHeader( cvSize(bmp.bmWidth, bmp.bmHeight)
, depth, nChannels );
data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
img->imageData =
(char*)malloc(bmp.bmHeight*bmp.bmWidth*nChannels*sizeof(char));
memcpy(img->imageData,(char*)(bmp.bmBits),bmp.bmHeight*bmp.bmWidth*nChannels);
data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
return img;
}
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt=""
data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" void createDIB(IplImage* &pict) {
IplImage * Red=cvCreateImage( cvSize(IMAGE_WIDTH,IMAGE_HEIGHT),
IPL_DEPTH_8U, 1 );
IplImage * Green=cvCreateImage( cvSize(IMAGE_WIDTH,IMAGE_HEIGHT),
IPL_DEPTH_8U, 1 );
IplImage * Blue=cvCreateImage( cvSize(IMAGE_WIDTH,IMAGE_HEIGHT),
IPL_DEPTH_8U, 1 );
cvSetImageCOI( pict, 3);
cvCopy(pict,Red);
cvSetImageCOI( pict, 2);
cvCopy(pict,Green);
cvSetImageCOI(pict, 1);
cvCopy(pict,Blue);
//Initialize the BMP display buffer
bmi = (BITMAPINFO*)buffer;
bmih = &(bmi->bmiHeader);
memset( bmih, 0, sizeof(*bmih));
bmih->biSize = sizeof(BITMAPINFOHEADER);
bmih->biWidth = IMAGE_WIDTH;
bmih->biHeight = IMAGE_HEIGHT; // -IMAGE_HEIGHT;
bmih->biPlanes = 1;
bmih->biCompression = BI_RGB;
bmih->biBitCount = 24;
palette = bmi->bmiColors;
data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" for( int i = 0; i < 256; i++ ) {
palette.rgbBlue = palette.rgbGreen = palette.rgbRed =
(BYTE)i;
palette.rgbReserved = 0;
}
cvReleaseImage(&Red);
cvReleaseImage(&Green);
cvReleaseImage(&Blue);
} |
文章评论(0条评论)
登录后参与讨论