【opencv/core module】(五)Adding (blending) two images using OpenCV

说在前面

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值