cvGetSubRect与cvMul用法

个人心得是最好不用cvGetSubRect,真的有点麻烦。

cvGetSubRect与cvMul用法

1、对于cvGetSubRect(mat1, mat2, rect),当用cvGetSubRect函数时,不能事先对mat2申请内存,否则会产生内存泄漏。

只要这样定义mat2即可:CvMat *mat2;
 mat2 = cvCreateMatHeader(imgHeight, imgWidth, CV_64FC1);

 

2、对于cvGetSubRect(mat1, mat2, rect)语句正确执行后,不能用cvMul直接执行:

cvMul(mat2, mat2, mat2),这样也会产生错误,改为以下语句即可:

CvMat *mat3;
mat3 = cvCloneMat(mat2);

cvMul(mat3, mat3, mat3);

 

另外:cvGetCol、cvGetCols、cvGetRow、cvGetRows、cvCloneImage与cvGetSubRect的用法相同,不能事先分配内存空间。

但是我在做实验的时候可以直接使用cvmul函数,得到的结果是正确的,当然我没有考虑内存的问题


(

[OpenCV] cvGetSubRect的使用

分类: OpenCV 1566人阅读 评论(4) 收藏 举报

使用cvGetSubRect时注意:不需要为cvMat申请内存!!!

实际上它会把源数据中的内存值直接付给这个cvMat的数据指针。如果事先申请了内存,调用cvGetSubRect的结果就是把原来申请的数据空间指针给覆盖了,程序就会丢失这个已经申请的内存区域的地址(内存泄露的产生);此时如果去释放这个cvMat,实际上是释放的cvMat的Header和源数据的相应空间,把源数据给消灭了(更惨)。

)


用截取的部分图像创建新图像--关于cvGetSubRect,cvGetImage的用法  

2011-03-27 22:49:17|  分类:opencv|字号 订阅

  CvMat* cvGetSubRect(const CvArr* arr, CvMat* submat, CvRect rect)可以把截取图像中需要的区域存入矩阵。把IplImage *传给arr,IplImage *指向所要截取的图像;把CvMat *传给submat(CvMat *只需为头指针就可以 不需要分配数据存储空间);rect是要截取的区域;返回指向所存矩阵。
例如:
  CvMat *pMat = cvCreateMatHeader(100, 100, CV_8UC1);  //创建一个100*100的矩阵头
  CvRect rect = cvRect(0, 0, 100, 100);  //要截取的区域,与创建的矩阵大小一样
  cvGetSubRect(pImg, pMat, rect);  //pImg为指向图像的指针,pMat指向存储所接图像的矩阵,返回值和pMat相等
也可以简化为:
  CvMat *pMat = cvGetSubRect(pImg, cvCreateMatHeader(100, 100, CV_8UC1), cvRect(0, 0, 100, 100));

  IplImage* cvGetImage( const CvArr* arr, IplImage* image_header )可以把刚才存入矩阵的数据转存为图像。把CvMat *传给arr;image_header 只需为图像头就行,不用分配数据存储空间;返回所存图像的指针。
例如:
  IplImage *pSubImg = cvCreateImageHeader(cvSize(100, 100), 8, 1);  //创建一个100*100的图像头
  cvGetImage(pMat, pSubImg); //pMat为存储数据的矩阵,pSubImg指向图像,返回值与pSubImg相等
也可以简化为:
  IplImage *pSubImg = cvGetImage(pMat, cvCreateImageHeader(cvSize(100, 100), 8, 1));

截取子图最后简化为:
  IplImage *pSubImg = cvGetImage(cvGetSubRect(pImg, cvCreateMatHeader(100, 100, CV_8UC1), cvRect(0, 0, 100, 100)), cvCreateImageHeader(cvSize(100, 100), 8, 1));  //好乱...读明白这句费劲儿

OpenCV版本2.0.0


你可能感兴趣的:(image,header,存储,opencv)