理论-线性混合操作
线性图像混合公式:
g(x) = (1 - a) * f0(x) + a * f1(x) (a∈[0,1])
其中a的取值范围为0~1之间
相关API (addWeighted)
void cvAddWeighted( const CvArr* src1, double alpha,const CvArr* src2, double beta,double gamma, CvArr* dst );
参数1:输入图像Mat – src1 参数2:输入图像src1的alpha值 参数3:输入图像Mat – src2 参数4:输入图像src2的alpha值 参数5:gamma值 参数6:输出混合图像 注意点:两张图像的大小和类型必须一致才可以 |
代码演示:(两张图片重叠显示)
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace std;
using namespace cv;
int main(int argc, char** argv)
{
Mat src1, src2, dst;
src1 = imread("linux.jpg");
src2 = imread("winxp.jpg");
if (!src1.data) {
cout << "could not load image. 1 ..." << endl;
return -1;
}
if (!src2.data) {
cout << "could not load image. 2 ..." << endl;
return -1;
}
double alpha = 0.5;
if (src1.rows == src2.rows && src1.cols == src2.cols && src1.type() == src2.type())
{
addWeighted(src1, alpha,src2,(1.0- alpha),0.0,dst);//两张图片合成一张
//multiply(src1,src2,dst,1.0);
imshow("linuxlogo",src1);
imshow("winxplogo", src2);
namedWindow("blend demo", CV_WINDOW_AUTOSIZE);
imshow("blend demo", dst);
}
else
{
printf("");
return -1;
}
waitKey(0);
return 0;
}