//有很多地方有介绍,但是很多不够详细,或者没有具体指明,这里我详细说明一下:chinabinlang;
typedef struct_IplImage
{
int nSize; /*IplImage结构的大小*/
int ID; /*图像头的版本*//* 版本 (=0)*/
int nChannels; /*通道数,据不同颜色类型的位图可取1、3、4*//*这里是指:每个位图像素是由几个点组成的,如,最经典的是24位位图,每个像素有RGB三个点组成,每个点是0~255(就是8位一个无符号字节,就是一个depth)*//*取值4,表示32位位图,有Alpha值,既位图透明度*/
intalphaChannel; /*Alpha通道数,没有取0,有则取4*/
int depth; /*每个通道的位数,可取1、8、16、32*//*这里具体指的就是:组成像素单个点的深度(既每个通道深度),一般都是无符号8位*//*一般图像概念所说的多少位位图是指像素的深度,如一个RGB位图就是 3*8=24,所以是24位位图;ARGB就是4*8=32,所以是32位位图;8位位图就是一个通道(一个单点)所有就是8位(既256色位图)*/
charcolorModel[4]; /*颜色模式,有Gray、RGB、RGBA、CMYK等*/
charchannelSeq[4]; /*通道顺序,如“RGB”、“BGR”等*/
int dataOrder; /*数据的排列方式,使用像素格式*/
int origin; /*坐标原点,有左上角和左下角两种*/
int align; /*图像数据的排列方式*/
int width; /*图像的宽*/
int height; /*图像的高*/
struct _IplROI*roi; /*指向ROI结构的指针,NULL表没有*/
struct _IplImage*maskROI; /*指向ROI模板的指针,NULL表没有*/
void *imageId; /*用于应用中,对于本库,可忽略*/
struct_IplTileInfo *tileInfo; /*该指针指向包含图像分解的信息*/
int imageSize; /*图像的大小*/
char *imageData; /*指向图像数据的指针*/
int widthStep; /*校准后的行字节数*/
intBorderMode[4]; /*边缘像素的模式*/
intBorderConst[4]; /*表示四个边的常数*/
char*imageDataOrigin; /*该指针指向完整的、没有校准的图像*/
} IplImage;
//这里转一篇文章,写的不错:
《OpenCV中IplImage图像格式与BYTE图像数据的转换 》
IplImage* iplImage;
BYTE* data;
1 由IplImage*得到BYTE*图像数据:
data = iplImage->imageDataOrigin; //未对齐的原始图像数据
或者
data = iplImage->imageData; //已对齐的图像数据
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 )指定图像数据,可以理解为将这个新图
像的数据指针指向了一个已存在的图像数据上,不存在图像数据存储空间的分配操 作。
注:当不再使用这个新图像时,要调用void cvReleaseImageHeader( IplImage**image )将它的图像
头释放!
3,如果有图像数据也有图像头(用于IplImage为静态分配存储空间的情 况),则先调用IplImage*
cvInitImageHeader( CvSize size, int depth, int channels )更改图像头,再调用void
cvSetData( CvArr* arr, void* data, int step )指定图像数据。
注:因为这个新图像使用的是其它图像的数据和已有的图像头,所以不能使用 cvReleaseImage将它的
头和图像数据释放,也不能使用cvReleaseData将它的图像数据释 放!
4,如果从已有的一个图像创建,则用IplImage* cvCloneImage( const IplImage*image ),它制作
图像的完整拷贝包括头、ROI和数据。
注:当不再使用这个新图像时,要调用void cvReleaseImage( IplImage** image )将它的头和图像数
据释放!