图像混合
图像混合就是将两个尺寸一样的图像按照一定的比例混合到一起,比如我们配置颜料,我们也是按照一定的比例去配置,所有的比例之和为1。
混合的方法有很多种,这里讲加权,相加,相乘
算法原理
我们用函数来表示一个图像,前提是所有的图像尺寸是一样的,即图像矩阵的行列一样,通道数一样
我们用 f0(x) 和 f1(x) 来表示输入的图像,用 g(x) 来表示输出图像,α表示比例( 0≤α≤1 ,一般来说,α取0和1没有太大意义),那我们能得到如下图所示的一个公式。
意思就是,两幅图像分别占的比例加起来是1,然后生成新图像
你也可以理解为,图像f1占比a,图像f0占比1-a,他们拼成图像gx
API
addWeighted
weighted是加权的意思,知道这个也就能很好的理解图像混合了,就是两张图象加权和
CV_EXPORTS_W void addWeighted(
InputArray src1,
double alpha,
InputArray src2,
double beta,
double gamma,
OutputArray dst,
int dtype = -1
);
参数1:输入图像Mat – src1
参数2:输入图像src1的alpha值(所占比重)
参数3:输入图像Mat – src2
参数4:输入图像src2的beta值(所占比重)
参数5:gamma值
参数6:输出混合图像
参数7:默认参数,不用管
要求两张图象大小一致
add
add(src1, src2, dst, mask, dtype)
src1:第1个输入图像或标量
src2:第2个输入图像或标量 dst:相加后的输出图像
mask:8位单通道图像,用于指定哪些像素需要相加
dtype:输出图像的深度(像素值位数)后两个参数可有可无
multiply
multiply(src1, src2, dst=None, scale=None, dtype=None)
src1:第1个输入图像或标量
src2:第2个输入图像或标量 dst:相加后的输出图像
mask:8位单通道图像,用于指定哪些像素需要相加
dtype:输出图像的深度(像素值位数)后两个参数可有可无
代码演示
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace std;
using namespace cv;
int main(int argc, char** argv) {
Mat src1, src2, dst;
src1 = imread("C:/Users/86176/Pictures/pics/lena(1).tiff");
src2 = imread("C:/Users/86176/Pictures/pics/woman1.tiff");
if (!src1.data) {
cout << "could not load image which named boy.png..." << endl;
return -1;
}
if (!src2.data) {
cout << "could not load image named girl.png..." << 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);
//add(src1, src2, dst, Mat());
imshow("src1", src1);
imshow("src2", src2);
imshow("dst", dst);
}
else {
printf("could not blend images , the size of images is not same...\n");
return -1;
}
waitKey(0);
return 0;
}
现象
src1
src2
addWeighted
看起来还可以的双重曝光效果
add
这个时候发现图像不是很好看
multiply
很难看
总结
使用图像混合时,一定要综合各种方案的效果进行综合选择