cvZero

来源:互联网 发布:玻璃破碎按钮 淘宝 编辑:程序博客网 时间:2024/05/17 23:29
IplImage*frame = cvCreateImage();

cvZero(frame);

新建图像后紧接着加个cvZero()函数,就是将图像中的每个像素都置为0,那么显示的frame自然就是全黑了。


cvCvtColor()

色彩空间转换函数

格式:cvCvtColor(源图像,输出图像,code)

code是指色彩空间转换的模式.

选用CV_BGR2GRAY时表示转换为灰度图片,BGR TO GRAY 原来是这个意思呀.

除了能转换成灰度之外还能转换成HSV等类型.

cvSmooth()

图像平滑函数

格式:cvSmooth(源图像,输出图像,smoothtype)

smoothtype是指平滑方法.

比如这么写 cvSmooth(pImg8u,pImg8uSmooth,CV_GAUSSIAN,3,0,0) = cvSmooth(pImg8u,pImg8uSmooth);

其实是一样的,因为后三个参数这么写其实是默认值

CV_GAUSSIAN (gaussian blur) - 对图像进行核大小为 param1×param2 的高斯卷积.

函数cvNot(const CvArr* src,CvArr* dst)会将src中的每一个元素的每一位取反,然后把结果赋给dst。因此,一个值为0x00的8位图像将被映射到0xff,而值为0x83的图像将被映射到0x7c。
void cvNot(
const CvArr* src,
CvArr* dst
);
{
for (int i = 0; i < height;i++)
for (int j = 0; j < width; j++)
for (int k = 0; k < channels; k++)
data[i*step + j*channels + k] = 255 - data[i*step + j*channels + k];
}

Opencv中cvCopy()和cvCloneImage()的区别:
 

cvCopy的原型是:
void cvCopy( const CvArr* src, CvArr* dst, const CvArr* mask=NULL );
在使用这个函数之前,你必须用cvCreateImage()一类的函数先开一段内存,然后传递给dst。cvCopy会把src中的数据复制到dst的内存中。
cvCloneImage的原型是:
IplImage* cvCloneImage( const IplImage* image );
在使用函数之前,不用开辟内存。该函数会自己开一段内存,然后复制好image里面的数据,然后把这段内存中的数据返回给你。

clone是把所有的都复制过来,也就是说不论你是否设置Roi,Coi等影响copy的参数,clone都会原封不动的克隆过来。
copy就不一样,只会复制ROI区域等。

用clone复制之后,源图像在内存中消失后,复制的图像也变了,而用copy复制,源图像消失后,复制的图像不变

cvCloneImage() 内存泄漏问题
cvCloneImage函数:
 
这个函数已验证会出现较大的内存泄露!!虽然可以释放,但因程序复杂不知道在那里释放,因为它每次拷贝是制作图像的完整拷贝包括头、ROI和数据。每次使用时编译器会分配新的内存空间,不会覆盖以前的内容。一个752*480大小或是稍小的图像,每次泄露的内存大约为1M。
 
解决方法:
使用cvCopy函数代替。
cvCopy(pSrcImg,pImg,NULL);   //代替 pImg = cvCloneImage(pSrcImg);
pImg初始化时必须分配空间,否则上述函数不能执行。 
pImg = cvCreateImage(cvSize(IMGWIDHT,IMGHEIGHT),IPL_DEPTH_8U, 3);
(使用此方法09-10-14已解决目前工程中因内存泄露而内存不足程序停止的问题




0 0
原创粉丝点击