cvAddWeighted( ) 是opencv中,将两个图片矩阵进行融合的一个很好的函数,可以得到很多有趣的效果。
其函数原型如下:
void cvAddWeighted( const CvArr* src1, double alpha,const CvArr* src2, double beta,double gamma, CvArr* dst );
src1
第一个原数组.
alpha
第一个数组元素的权值
src2
第二个原数组
beta
第二个数组元素的权值
dst
输出数组
gamma
添加的常数项。
函数 cvAddWeighted 计算两数组的加权值的和:
dst(I)=src1(I)*alpha+src2(I)*beta+gamma
所有的数组必须的相同的类型相同的大小(或ROI大小)
注意:在这里src1,src2,以及dst,都必须是同样的图片类型,如:IPL_DEPTH_8U,在调用cvLoadImage( ) 时,打开方式也必须完全相同,这里1表示以三通道彩色图像方式输入,0表示以灰度图片格式输入,-1表示以原来图片的格式输入
看个例子:
#include "stdafx.h" #include "cv.h" #include "highgui.h" int main(int argc, char* argv[]) { IplImage *src1,*src2; if(argc == 9 && (src1=cvLoadImage(argv[1],1))!=0 && (src2=cvLoadImage(argv[2],1))!=0) { IplImage *image=cvCreateImage(cvSize(275,313),IPL_DEPTH_8U,3); cvResize(src2,image); int x= atoi(argv[3]); int y= atoi(argv[4]); int width= atoi(argv[5]); int height= atoi(argv[6]); double alpha=(double)atof(argv[7]); double beta=(double)atof(argv[8]); cvSetImageROI(src1,cvRect(x,y,width,height)); cvSetImageROI(image,cvRect(10,10,width,height)); cvAddWeighted(src1,alpha,image,beta,0.0,src1); cvResetImageROI(src1); cvNamedWindow("Alpha_bend",1); cvShowImage("Alpha_bend",src1); cvWaitKey(0); cvReleaseImage(&src1); cvReleaseImage(&src2); cvDestroyWindow("Alpha_bend"); } return 0; }
我的命令行参数是:cvAddWeighted.exe lena.jpg cat.jpg 235 221 115 156 0.8 0.2
当然这里还可以自己调整。
这里由于cat.jpg图片比较大,我先对他进行缩放,然后在和lena.jpg进行图片融合,当然融合的坐标点我实在ps里得到的。