图像混合的原理
理论-线性混合操作
其中 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,转载请注明出处!讨论可扫码加群:


