-
图像混合简介:
图像混合是图像处理技术中的一个技术名词。主要功效是可以用不同的方法将对象颜色与底层对象的颜色混合。当您将一种混合模式应用于某一对象时,在此对象的图层或组下方的任何对象上都可看到混合模式的效果。首先学习最简单、最基础的混合操作——线性混合 -
线性混合操作
对于两张图片f(x)与h(x),目标图片g(x)为二者混合的结果,则其混合我们可以用公式
g(x)=a*f(x)+(1-a)*h(x)来表示,a代表混合后f(x)在混合图片g(x)中的权重 -
图像混合在OpenCV中的实现:
① OpenCV中实现两张图片的初级线性混合第一种方式是使用addWeighted函数来实现
addWeighted函数原型为:
void cv::addWeighted(InputArray src1,double alpha,InputArray src2,double beta,double grammma,OutputArray dst,int dtype = -1)
我们需要注意的是对于addWeighted函数我们必须在两张图片src1与src2大小格式完全相同的情况下才能进行混合操作``` #include <opencv2\opencv.hpp> #include <iostream> using namespace std; using namespace cv; int main() { Mat src1, src2, dst; src1 = imread("C:/Users/he104/Desktop/lol.jpg"); src2 = imread("C:/Users/he104/Desktop/ow.jpg"); if (src1.empty()) { cout << "could not load the lol.jpg" << endl; return -1; } if (src2.empty()) { cout << "could not load the ow.jpg" << endl; return -1; } namedWindow("src1", CV_WINDOW_AUTOSIZE); imshow("src1", src1); namedWindow("src2", CV_WINDOW_AUTOSIZE); imshow("src2", src2); double alpha; double beta; alpha = 0.5; beta = 1.0 - alpha; if ((src1.rows == src2.rows) && (src1.cols == src2.cols) && (src1.type() == src2.type())) { addWeighted(src1, alpha, src2, beta, 0.0, dst); namedWindow("blend", CV_WINDOW_AUTOSIZE); imshow("blend", dst); } else { cout << "could not load src1 and src2..." << endl; return -1; } waitKey(0); destroyAllWindows(); return 0; } ```
②通过add()函数进行线性混合操作
③通过multiply()函数进行线性混合操作
第二种与第三种混合方式的混合效果不如第一种
OpenCV学习5——图像混合
最新推荐文章于 2022-04-25 21:36:21 发布