对IplImage 结构体的理解

 1 typedef struct _IplImage  
 2     {  
 3         int  nSize;         /* IplImage大小 */  
 4         int  ID;            /* 版本 (=0)*/  
 5         int  nChannels;     /* 大多数OPENCV函数支持1,2,3 或 4 个通道 */  
 6         int  alphaChannel;  /* 被OpenCV忽略 */  
 7         int  depth;         /* 像素的位深度: IPL_DEPTH_8U, IPL_DEPTH_8S, IPL_DEPTH_16U, 
 8                                IPL_DEPTH_16S, IPL_DEPTH_32S, IPL_DEPTH_32F and IPL_DEPTH_64F 可支持 */  
 9         char colorModel[4]; /* 被OpenCV忽略 */  
10         char channelSeq[4]; /* 同上 */  
11         int  dataOrder;     /* 0 - 交叉存取颜色通道, 1 - 分开的颜色通道. 
12                                cvCreateImage只能创建交叉存取图像 */  
13         int  origin;        /* 0 - 顶—左结构, 
14                                1 - 底—左结构 (Windows bitmaps 风格) */  
15         int  align;         /* 图像行排列 (4 or 8). OpenCV 忽略它,使用 widthStep 代替 */  
16         int  width;         /* 图像宽像素数 */  
17         int  height;        /* 图像高像素数*/  
18         struct _IplROI *roi;/* 图像感兴趣区域. 当该值非空只对该区域进行处理 */  
19         struct _IplImage *maskROI; /* 在 OpenCV中必须置NULL */  
20         void  *imageId;     /* 同上*/  
21         struct _IplTileInfo *tileInfo; /*同上*/  
22         int  imageSize;     /* 图像数据大小(在交叉存取格式下imageSize=image->height*image->widthStep),单位字节*/  
23         char *imageData;  /* 指向排列的图像数据 */  
24         int  widthStep;   /* 排列的图像行大小,以字节为单位 */  
25         int  BorderMode[4]; /* 边际结束模式, 被OpenCV忽略 */  
26         int  BorderConst[4]; /* 同上 */  
27         char *imageDataOrigin; /* 指针指向一个不同的图像数据结构(不是必须排列的),是为了纠正图像内存分配准备的 */  
28     }  
29     IplImage;  

其中,width表示图像的每行像素数。
widthStep表示存储一行像素需要的字节数。
imageData表示指向图像数据实际实际地址,注意是实际地址,不同于二维数组a[][]的首地址。
nChannels通道简单来说就是,灰度图像通道数为1,彩色图像通道数为3,即RGB图像每个像素点有3个通道。



posted @ 2013-04-23 20:15  uriboyka  阅读(293)  评论(0)    收藏  举报