对IplImage 结构体的理解
生活随笔
收集整理的這篇文章主要介紹了
对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個通道。
其中,width表示圖像的每行像素數。
widthStep表示存儲一行像素需要的字節數。
imageData表示指向圖像數據實際實際地址,注意是實際地址,不同于二維數組a[][]的首地址。
nChannels通道簡單來說就是,灰度圖像通道數為1,彩色圖像通道數為3,即RGB圖像每個像素點有3個通道。
轉載于:https://www.cnblogs.com/uriboyka/archive/2013/04/23/3038711.html
總結
以上是生活随笔為你收集整理的对IplImage 结构体的理解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Web API核查表:设计、测试、发布A
- 下一篇: 文档容器iOS网络编程-iCloud文档