图像混合的原理
理论-线性混合操作

其中 a的取值范围为0~1之间
对应的opencv算子是 addWeighted()


参数1:输入图像Mat – src1
参数2:输入图像src1的alpha值
参数3:输入图像Mat – src2
参数4:输入图像src2的alpha值
参数5:gamma值
参数6:输出混合图像
注意点:两张图像的大小和类型必须一致才可以
演示代码:
#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h>
using namespace cv;
int main(int argc, char** argv) {
	Mat src1,src2,dst;
	src1 = imread("e:/6.bmp");
	src2 = imread("e:/5.png");
	double alpha = 0.5;
	if (src1.rows == src2.rows && src1.cols == src2.cols &&
		src1.type() == src2.type()) {
		//add(src1, src2, dst, Mat());
		//multiply(src1, src2, dst, 0.01);
		addWeighted(src1, alpha, src2, (1.0 - alpha), 0, dst);
		imshow("win1", src1);
		imshow("win2", src2);
		imshow("win3", dst);
	}
	else {
		printf("两张图片不同,不能混合!");
		return -1;
	}
	
	waitKey(0);
	return 0;
}
addWeighted()的效果

add()的效果

multiply()的效果
---------------------
作者:hackpig
来源:www.skcircle.com
版权声明:本文章代码及资料部分或全部来自贾志刚老师的视频,勇哥只是在个人理解的基础上做学习笔记,转载请附上博文链接!
本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:



 少有人走的路
少有人走的路



















