OpenCV中IplImage图像格式与BYTE图像数据的转换
IplImage* iplImage;
BYTE* data;
1 由IplImage*得到BYTE*图像数据:
data = iplImage->imageDataOrigin; //未对齐的原始图像数据
或者
data = iplImage->imageData; //已对齐的图像数据
注意:此处暂时存疑,因为据该帖子http://www.opencv.org.cn/forum/viewtopic.php?f=1&t=4812&p=9862&st=0&sk=t&sd=a所述,实际上imagedata和imagedataorigin基本上是没什么区别的。他们都指向同一块内存区域。而至于为什么要留两个一样的东西imagedata和imagedataorigin,可能原因是:预留数据接口吧!上面有这么一句话:IplImage结构来自于 Intel Image Processing Library(是其本身所具有的)。
2 由BYTE*得到IplImage*图像数据
iplImage = cvCreateImageHeader(cvSize(width,height),depth,channels);
cvSetData(iplImage,data,step);
首先由cvCreateImageHeader()创建IplImage图像头,制定图像的尺寸,深度和通道数;然后由cvSetData()根据 BYTE*图像数据指针设置IplImage图像头的数据数据,其中step指定该IplImage图像每行占的字节数,对于1通道的 IPL_DEPTH_8U图像,step可以等于width。
1,如果是从新创造一个Iplimage,则用IplImage* cvCreateImage( CvSize size, int depth, int channels ),它创建头并分配数据。
注:当不再使用这个新图像时,要调用void cvReleaseImage( IplImage** image )将它的头和图像数据释放!
2,如果有图像数据没有为图像头分配存储空间(即,没有为IplImage*指针分配动态存储空间),则先调用IplImage* cvCreateImageHeader( CvSize size, int depth, int channels )创建图像头,再调用void cvSetData( CvArr* arr, void* data, int step )指定图像数据,可以理解为将这个新图像的数据指针指向了一个已存在的图像数据上,不存在图像数据存储空间的分配操作。
示例如下:
IplImage* image = cvCreateImageHeader(cvSize(15, 15), 8, 1);
char* data = new char[15*15];
cvSetData(image, data, 15);
cvReleaseImageHeader(&image);
delete []data;
3,如果有图像数据也有图像头(用于IplImage为静态分配存储空间的情况),则先调用IplImage*cvInitImageHeader( CvSize size, int depth, int channels )更改图像头,再调用voidcvSetData( CvArr* arr, void* data, int step )指定图像数据。
注:因为这个新图像使用的是其它图像的数据和已有的图像头,所以不能使用cvReleaseImage将它的头和图像数据释放,也不能使用cvReleaseData将它的图像数据释放!
4,如果从已有的一个图像创建,则用IplImage* cvCloneImage( const IplImage* image ),它制作图像的完整拷贝包括头、ROI和数据。
注:当不再使用这个新图像时,要调用void cvReleaseImage( IplImage** image )将它的头和图像数据释放!
本文介绍了如何在OpenCV中实现IplImage格式与BYTE图像数据之间的转换。详细讲解了通过IplImage*获取BYTE*图像数据的方法,并给出了从BYTE*创建IplImage*图像数据的具体步骤。此外还讨论了不同情况下IplImage的创建与释放。
1156

被折叠的 条评论
为什么被折叠?



