IplImage的使用
IplImage是通过cvLoadImage一jpg图片得到的,而我的程序里是利用v4l2驱动从摄像头读到的UYVY格式的数据,因此想自己来创建这个IplImage的结构体。
IplImage 结构解读:
typedef struct _IplImage
{
int nSize;
/* IplImage大小 */
int ID;
/* 版本 (=0)*/
int nChannels;
/* 大多数OPENCV函数支持1,2,3 或 4 个通道 */
int alphaChannel;
/* 被OpenCV忽略 */
int depth;
/* 像素的位深度: IPL_DEPTH_8U, IPL_DEPTH_8S, IPL_DEPTH_16U,
IPL_DEPTH_16S, IPL_DEPTH_32S, IPL_DEPTH_32F and IPL_DEPTH_64F 可支持 */
char colorModel[4];
/* 被OpenCV忽略 */
char channelSeq[4];
/* 同上 */
int dataOrder;
/* 0 - 交叉存取颜色通道, 1 - 分开的颜色通道.
cvCreateImage只能创建交叉存取图像 */
int origin;
/* 0 - 顶—左结构,1 - 底—左结构 (Windows bitmaps 风格) */
int align;
/* 图像行排列 (4 or 8). OpenCV 忽略它,使用 widthStep 代替 */
int width;
/* 图像宽像素数 */
int height;
/* 图像高像素数*/
struct _IplROI *roi;
/* 图像感兴趣区域. 当该值非空只对该区域进行处理 */
struct _IplImage *maskROI;
/* 在 OpenCV中必须置NULL */
void *imageId;
/* 同上*/
struct _IplTileInfo *tileInfo;
/*同上*/
int imageSize;
/* 图像数据大小(在交叉存取格式下imageSize=image->height*image->widthStep),单位字节*/
char *imageData;
/* 指向排列的图像数据 */
int widthStep;
/* 排列的图像行大小,以字节为单位 */
int BorderMode[4];
/* 边际结束模式, 被OpenCV忽略 */
int BorderConst[4];
/* 同上 */
char *imageDataOrigin;
/* 指针指向一个不同的图像数据结构(不是必须排列的),是为了纠正图像内存分配准备的 */
}
IplImage;
重要结构元素说明:
depth和nChannels
depth代表颜色深度,使用的是以下定义的宏,nChannels是通道数,为1,2,3或4。
depth的宏定义:
IPL_DEPTH_8U,无符号8bit整数(8u)
IPL_DEPTH_8S,有符号8bit整数(8s)
IPL_DEPTH_16S,有符号16bit整数(16s)
IPL_DEPTH_32S,有符号32bit整数(32s)
IPL_DEPTH_32F,32bit浮点数,单精度(32f)
origin和dataOrder
origin 变量可以有两个取值:IPL_ORIGIN_TL或者IPL_ORIGIN_BL,分别代表图像坐标系原点在左上角或是左下角。相应的,在计算机视觉领 域,一个重要的错误来源就是原点位置的定义不统一。例如,图像的来源不同,操作系统不同,视频解码codec不同,存储方式不同等等,都可以造成原点位置 的变化。例如,你可能认为你正在从图像上面的脸部附近取样,但实际上你却在图像下方的裙子附近取样。最初时,就应该检查一下你的系统中图像的原点位置,这 可以通过在图像上方画个形状等方式实现。
dataOrder的取值可以是IPL_DATA_ORDER_PIXEL或者 IPL_DATA_ORDER_PLANE,这个成员变量定义了多通道图像数据存储时颜色数据的排列方式,如果是 IPL_DATA_ORDER_PIXEL,通道颜色数据排列将会是BGRBGR...的交错排列,如果是IPL_DATA_ORDER_PLANE,则 每个通道的颜色值在一起,有几个通道,就有几个“颜色平面”。大多数情况下,通道颜色数据的排列是交错的。
widthStep与CvMat中的step类似,是以字节数计算的图像的宽度。成员变量imageData则保存了指向图像数据区首地址的指针。
最 后还有一个重要参数roi(region of interest 感兴趣的区域),这个参数是IplROI结构体类型的变量。IplROI结构体包含了xOffset,yOffset,height,width,coi 成员变量,其中xOffset,yOffset是x,y坐标,coi代表channel of interest(感兴趣的通道)。有时候,OpenCV图像函数不是作用于整个图像,而是作用于图像的某一个部分。这是,我们就可以使用roi成员变量 了。如果IplImage变量中设置了roi,则OpenCV函数就会使用该roi变量。如果coi被设置成非零值,则对该图像的操作就只作用于被coi 指定的通道上了。不幸的是,许多OpenCV函数忽略了coi的值。
访问图像中的数据
就 象访问矩阵中元素一样,我们希望用最直接的办法访问图像中的数据,例如,如果我们有一个三通道HSV图像(HSV色彩属性模式是根据色彩的三个基本属性: 色相H、饱和度S和明度V来确定颜色的一种方法),我们要将每个点的饱和度和明度设置成255,则我们可以使用指针来遍历图像,请对比一下,与矩阵的遍历 有何不同:
void sat_sv( IplImage* img ) {
for( int y=0; y<height; y++ ) {
uchar* ptr = (uchar*) (
img->imageData + y * img->widthStep
);
for( int x=0; x<width; x++ ) {
ptr[3*x+1] = 255;
ptr[3*x+2] = 255;
}
}
}
注 意一下,3*x+1,3*x+2的方法,因为每一个点都有三个通道,所以这样设置。另外imageData成员的类型是uchar*,即字节指针类型,所 以与CvMat的data指针类型(union)不同,而不需要象CvMat那样麻烦(还记得step/4,step/8的那种情形吗)。
roi和widthStep
roi 和widthStep在实际工作中有很重要的作用,在很多情况下,使用它们会提高计算机视觉代码的执行速度。这是因为它们允许对图像的某一小部分进行操 作,而不是对整个图像进行运算。在OpenCV中,所有的对图像操作的函数都支持roi,如果你想打开roi,可以使用函数 cvSetImageROI(),并给函数传递一个矩形子窗口。而cvResetImageROI()是用于关闭roi的。
void cvSetImageROI(IplImage* image,CvRect rect);
void cvResetImageROI(IplImage* image);
注意,在程序中,一旦使用了roi做完相应的运算,就一定要用cvResetImageROI()来关闭roi,否则,其他操作执行时还会使用roi的定义。
外,补充一下,“利用cvCreateImage新建一个IplImage,之后一个个的对结构体的成员进行赋值”是非常多余
的,cvCreateImage就已经根据参数中的宽度,高度,通道数,颜色深度等信息对结构体的各个成员初始化了,不需要再手动的去赋值。这里要提一下char *imageDataOrigin; 这个变量的说明是指针指向一个不同的图像数据结构(不是必须排列的),是为了纠正图像内存分配准备的,实际上初始化后的imageDataOrigin和 imageData指向的是同一个地址。既然初始化成这样,我也没去改变它,没有产生什么影响。opencv论坛上sunlighta大侠的解释是:“预留数据接口吧!上面有这么一句话:IplImage结构来自于 Intel Image Processing Library(是其本身所具有的)。OpenCV 只支持其中的一个子集。”
IplImage的使用相关推荐
- Mat,Iplimage,vector,vector_vector_Point2f等类型之间的相互转换
在mfc c++ 以及opencv 编写程序当中,很多常用的类型转换,现在总结一下.(注意加相应的头文件,这里不罗嗦) 提纲: 1. Mat ---> Iplimage 2. Iplimage ...
- CvMat,Mat和IplImage之间的转化和拷贝
1.CvMat之间的复制 ``` //注意:深拷贝 - 单独分配空间,两者相互独立 CvMat* a; CvMat* b = cvCloneMat(a); //copy a to b ``` 2.Ma ...
- IplImage 类型和 CvMat 类型转换为 Mat 类型
IplImage *IplImg = cvLoadImage("fruits.jpg"); Mat img(IplImg, true); 转载:http://blog.csdn.n ...
- Mat转换为IplImage 类型和CvMat 类型
cv::Mat img; CvMat cvMatImg = img; IplImage IplImg = img; 转载:http://blog.csdn.net/zhuwei1988
- OpenCV中IplImage和单字节char*的相互转换
已知 IplImage* image 和 char* data 从 IplImage 到 char* : data = image->imageData //对齐的图像数据 或者 data = ...
- opencv各版本 IplImage Mat 转换
#include <iostream> #include <opencv2/highgui/highgui.hpp> using namespace cv; using nam ...
- OpenCV之CvMat Mat IplImage之间相互转换
下面是亲测的: IplImage* iplimg = cvLoadImage("heels.jpg"); cv::Mat matimg; cvConvert(matimg,ipli ...
- 对于2.3版的OpenCV的IplImage,最好不要直接操作其imageData成员~
对于2.3版的OpenCV的IplImage,最好不要直接操作其imageData成员~为啥?因为它这里定义的char类型,而真正的应该是unsigned char类型,这是一个明显的bug,所以要操 ...
- 看懂OpenCV中IplImage转换成CvMat的语句:CvMat sstub, *src = cvGetMat(srcarr, sstub);
图像处理开发需求.图像处理接私活挣零花钱,请加微信/QQ 2487872782 图像处理开发资料.图像处理技术交流请加QQ群,群号 271891601 知识预备请看链接: IplImage, CvMa ...
- IplImage简介
IplImage简介 结构定义: typedef struct _IplImage {int nSize; /* sizeof(IplImage) */int ID; /* version (=0)* ...
最新文章
- 【c语言】蓝桥杯算法训练 大小写判断
- C语言再学习 -- 三字母词(转)
- wxWidgets:字体编码
- Product Long text - children usage
- python3-matplotlib绘制散点图、绘制条形图
- 华为鸿蒙发布作文,华为鸿蒙OS定档6月2日发布!MatePad Pro 2或同台亮相:首发预装...
- miniui 样式第一次加载不出来_matplotlib--修改样式
- java jar killed_我的Java应用程序被OOMKilled了,原因竟是这样?
- Gradle 插件Debug调试
- L2-3 清点代码库 (25 分)(C/C++)
- python自动发送短信验证码、短信通知、营销短信、语音短信
- 使用keil安装目录下的相关驱动进行安装
- SQL基本语句使用总结
- 关于优秀的管理者学习笔记
- kali linux nmap扫描(二)_商洛学院司徒荆_新浪博客
- 2019网络购车平台易车的发展
- three.js学习笔记(四)——Lights灯光
- 计算机cad的概念,【2人回答】什么是CAD?CAD的含义是什么?-3D溜溜网
- 计算机二级access分数分布_全国计算机等级考试2017年上半年二级ACCESS数据库成绩查询...
- MatLab归一化说明
热门文章
- docx下载打不开php,从PHP下载时Word / Excel文件已损坏
- 系统内存管理介绍,内存申请及回收流程
- HtmlUtils把HTML编码转义,可将HTML标签互相转义
- CentOS 7 部署 YApi 并集成ladp
- 企业邮箱价格,集团企业邮箱注册价格,买2年送2年
- 【软件测试】使用selenium工具对Web聊天室项目进行UI自动化测试
- 阿里云推送 AndroidSDK 3.0 快速集成
- HTML5的画布:Stroke(笔触)和Fill(填充)
- 【UML】交互图(顺序图、合作图\协作图)
- Qt创建的工程,无法编译,提示找到不文件Cannot find file,是怎么回事