1、理论-线性混合操作
2、相关API(addWeighted)
解释说明:
- 参数1:inputArray src1 表示 输入图像Mat_src1
- 参数2:double alpha 表示 输入图像src1的alpha值(第一个权重即α)
- 参数3:inputArray src2 表示 输入图像Mat – src2
- 参数4:double beta 表示 输入图像src2的alpha值(第二个权重即1-α)
- 参数5:gamma值(校验值)
- 参数6:OutputArray dst 表示 输出混合图像
- dtype=-1:为默认值
计算公式为:
注意点:两张图像的大小和类型必须一致才可以
3、介绍图像基本运算的几种函数
void add(InputArray src1, InputArray src2, OutputArray dst,InputArray mask=noArray(), int dtype=-1);//dst = src1 + src2
void subtract(InputArray src1, InputArray src2, OutputArray dst,InputArray mask=noArray(), int dtype=-1);//dst = src1 - src2
void multiply(InputArray src1, InputArray src2,OutputArray dst, double scale=1, int dtype=-1);//dst = scale*src1*src2
void divide(InputArray src1, InputArray src2, OutputArray dst,double scale=1, int dtype=-1);//dst = scale*src1/src2
void divide(double scale, InputArray src2,OutputArray dst, int dtype=-1);//dst = scale/src2
void scaleAdd(InputArray src1, double alpha, InputArray src2, OutputArray dst);//dst = alpha*src1 + src2
void addWeighted(InputArray src1, double alpha, InputArray src2,double beta, double gamma, OutputArray dst, int dtype=-1);//dst = alpha*src1 + beta*src2 + gamma
void sqrt(InputArray src, OutputArray dst);//计算每个矩阵元素的平方根
void pow(InputArray src, double power, OutputArray dst);//src的power次幂
void exp(InputArray src, OutputArray dst);//dst = e**src(**表示指数的意思)
void log(InputArray src, OutputArray dst);//dst = log(abs(src))
4、代码实例
#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/86180/Desktop/文档/学习/opencv/图片处理/zqy4_1.jpg");
src2 = imread("C:/Users/86180/Desktop/文档/学习/opencv/图片处理/zqy5_1.jpg");
if (!src1.data) {
cout << "could not load image..4." << endl;
return -1;
}
if (!src2.data) {
cout << "could not load image..5." << 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);
imshow("zqy4", src1);
imshow("zqy5", src2);
namedWindow("blend demo", WINDOW_AUTOSIZE);
imshow("blend demo", dst);
}
else
{
cout << "could not blend images, the size of images is not same..." << endl;
return -1;
}
waitKey(0);
return 0;
}
运行结果如下:
原图:
混合之后的图:
如果代码进行一下修改:
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);
add(src1, src2, dst, Mat());//修改的地方在这里(相加)
imshow("zqy4", src1);
imshow("zqy5", src2);
namedWindow("blend demo", WINDOW_AUTOSIZE);
imshow("blend demo", dst);
}
else
{
cout << "could not blend images, the size of images is not same..." << 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);
//add(src1, src2, dst, Mat());
multiply(src1, src2, dst, 1.0);//修改的地方在这里(相乘)
imshow("zqy4", src1);
imshow("zqy5", src2);
namedWindow("blend demo", WINDOW_AUTOSIZE);
imshow("blend demo", dst);
}
else
{
cout << "could not blend images, the size of images is not same..." << endl;
return -1;
}
其运行结果为: