IplImage
中的OpenCV
是什么?你能解释一下它的含义吗?我们什么时候应该使用它?
感谢。
答案 0 :(得分:23)
基于您在问题中的'c ++'标记: 你不应该使用它,你应该使用cv :: Mat。每个IplImage内部都是一个cv :: Mat。
IplImage仅用于C API。它是一种CvMat并保存图像数据。它的名字源自OpenCV的根源(Intel IPL)。
如果您使用OpenCV的C ++ API,则不再相关。
答案 1 :(得分:22)
IplImage和cv :: Mat是矩阵/图像数据的不同标头类型。它们基本上是相互兼容的,但IplImage用于OpenCV的C API,而cv :: Mat用于 new C ++ API。
当您决定使用OpenCV的C API时,您将主要使用IplImages。否则你将主要使用cv :: Mats。
当然,您可以将IplImages和cv :: Mats互相转换,例如
cv::Mat mat(myIplImage);
在这种情况下,它们共享相同的基础数据,即无论您使用什么标头访问数据,都可以看到通过任一标头进行的修改。
可以进行深度复制(不仅可以“转换”/复制标题,还可以复制基础数据)
cv::Mat mat(myIplImage, true)
请注意,多个IplImages也可以指向相同的基础数据,多个cv :: Mats也可以。
使用OpenCV和类似的库时,重要的是要注意cv :: Mats和IplImages只是实际数据的“标题”。 您可以说cv :: Mats和IplImages基本上是指针加上重要的元信息,例如行数,列数,通道数以及用于矩阵/图像的单个单元格/像素的数据类型。 并且,与实际指针一样,它们可以引用/指向相同的真实数据。
例如,查看IplImage的定义:http://opencv.willowgarage.com/documentation/basic_structures.html#iplimage
最重要的成员是char *imageData;
。该指针引用实际图像数据。但是,IplImage 作为一个整体包含有关图像的元信息,例如行数和列数。
答案 2 :(得分:2)
IplImage结构继承自英特尔图像处理库,其格式为原生。 OpenCV仅支持可能的IplImage格式的子集,如上面的参数列表中所述。
答案 3 :(得分:0)
如果您使用的是C ++,则不要使用IplImage,因为这仅用于C程序,(IplImage在C API中)。 此外,如果您使用C,则需要在变量名称之前发布Cv:“CvMat *”“CvPoint ”“IplImage < / em> “等 最好使用C ++代码,不要使用Cv:“Mat * ”等但是你不能使用IplImage类型,而不是IplImage你在findchessboardcorner函数中使用Mat类型。