说在前面
- opencv版本:4.0.1
- 操作系统:win10
- vs版本:2017
- 官方文档:Adding (blending) two images using OpenCV
- 其他说明:自学,记录,demo
Theory
-
一个很简单的加权操作:
g ( x ) = ( 1 − α ) f 0 ( x ) + α f 1 ( x ) g(x) = (1-\alpha)f_0(x) + \alpha f_1(x) g(x)=(1−α)f0(x)+αf1(x)
其中 α ∈ [ 0 , 1 ] \alpha \in [0,1] α∈[0,1]
我们对图像的每个像素的每个通道单独进行以上操作,得出的值作为输出图像对应位置的值。对于两幅图像,当 α = 0 \alpha=0 α=0时,就是第一幅图;当 α = 1 \alpha=1 α=1时,就是第二幅图。当 α \alpha α从0逐渐变为1时,显现出来的效果就像ppt里的浮现效果那样。
SourceCode
#include "opencv2/imgcodecs.hpp"
#include "opencv2/highgui.hpp"
#include <iostream>
using namespace cv;
// we're NOT "using namespace std;" here,
//to avoid collisions between the beta variable and std::beta in c++17
//这里beta是c++17中已定义的变量,所以要防止冲突?
using std::cin;
using std::cout;
using std::endl;
int main(void)
{
double alpha = 0.0; double beta; double input;
Mat src1, src2, dst;
src1 = imread("add1.jpg");//输入图片1
src2 = imread("add2.jpg");//输入图片2
if (src1.empty()) { cout << "Error loading src1" << endl; return -1; }
if (src2.empty()) { cout << "Error loading src2" << endl; return -1; }
//参数 文件名、编码格式、帧率、大小
VideoWriter writer("test.avi", VideoWriter::fourcc('M', 'J', 'P', 'G'),
25.0, Size(src1.cols, src1.rows));
while (alpha < 1)
{
beta = (1.0 - alpha);
//主角
addWeighted(src1, alpha, src2, beta, 0.0, dst);
imshow("Linear Blend", dst);
//显示间隔
waitKey(20);
//alpha逐渐变大
alpha += 0.02;
//通过writer将dst输出到视频文件中
writer << dst;
}
return 0;
}
- 主要讲一下addWeight(),实现了
d s t ( I ) = s a t u r a t e ( s r c 1 ( I ) ∗ α + s r c 2 ( I ) ∗ β + γ ) dst(I)=saturate ( src1(I)∗\alpha+src2(I)∗\beta+\gamma) dst(I)=saturate(src1(I)∗α+src2(I)∗β+γ)
saturate防止值溢出,之前说过
void cv::addWeighted
(
InputArray src1, //输入图像1
double alpha, //图像1所占的权重 α
InputArray src2, //输入图像2
double beta, //图像2所占的权重 β
double gamma, //常量 γ
OutputArray dst, //输出图像
int dtype = -1 //输出图像的depth,depth之前有讲过
)
Result
- 为了便于显示,我将输出的视频转换成了gif(不是opencv转的,2M左右)
- 这一节应该比较简单?
END-(CSDN)2019.6.28