当前位置: 首页 > article >正文

OpenCV杂项图像变换(2)线性混合函数blendLinear()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

执行两个图像的线性混合:
dst ( i , j ) = weights1 ( i , j ) ∗ src1 ( i , j ) + weights2 ( i , j ) ∗ src2 ( i , j ) \texttt{dst}(i,j) = \texttt{weights1}(i,j)*\texttt{src1}(i,j) + \texttt{weights2}(i,j)*\texttt{src2}(i,j) dst(i,j)=weights1(i,j)src1(i,j)+weights2(i,j)src2(i,j)
blendLinear 函数是 OpenCV 中用于实现线性混合的一种方法。这个函数可以将多个图像按照指定的权重进行混合,生成一个新的图像。这对于图像融合或者创建过渡效果非常有用。

函数原型


void cv::blendLinear	
(
	InputArray 	src1,
	InputArray 	src2,
	InputArray 	weights1,
	InputArray 	weights2,
	OutputArray 	dst 
)		

参数

  • 参数src1 它的类型为 CV_8UC(n) 或 CV_32FC(n),其中 n 是一个正整数。
  • 参数src2 它具有与 src1 相同的类型和大小。
  • 参数weights1 它的类型为 CV_32FC1 并且与 src1 具有相同的大小。
  • 参数weights2 它的类型为 CV_32FC1 并且与 src1 具有相同的大小。
  • 参数dst 如果它没有与 src1 相同的大小和类型,则会创建它。

代码示例

#include <opencv2/opencv.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>

using namespace cv;

int main(int argc, char** argv)
{
    // 读取图像
    Mat image1 = imread("/media/dingxin/data/study/OpenCV/sources/images/top.jpg");
    Mat image2 = imread("/media/dingxin/data/study/OpenCV/sources/images/bottom.jpg");

    if (image1.empty() || image2.empty()) {
        std::cerr << "Error: Could not open or find the images." << std::endl;
        return -1;
    }

    // 确保两个图像的大小一致
    if (image1.size() != image2.size()) {
        std::cerr << "Error: Images must have the same size." << std::endl;
        return -1;
    }

    cv::resize(image2, image2, image1.size());

    // 创建权重图像
    Mat weights1(image1.size(), CV_32FC1, Scalar(0.5));
    Mat weights2(image1.size(), CV_32FC1, Scalar(0.5));

    std::cout<<image1.size()<<" "<<image2.size()<<weights1.size()<<weights2.size()<<std::endl;

    // 创建输出图像

    // 创建输出图像
    Mat blendedImage;

    // 应用线性混合
    blendLinear(image1, image2, weights1, weights2, blendedImage);

    // 显示结果
    namedWindow("Image 1", WINDOW_NORMAL);
    imshow("Image 1", image1);

    namedWindow("Image 2", WINDOW_NORMAL);
    imshow("Image 2", image2);

    namedWindow("Blended Image", WINDOW_NORMAL);
    imshow("Blended Image", blendedImage);

    waitKey(0);

    return 0;
}

运行结果

在这里插入图片描述


http://www.kler.cn/a/282806.html

相关文章:

  • opc da 服务器数据 转 IEC61850项目案例
  • golang使用etcd版本问题
  • 第四十五章 Vue之Vuex模块化创建(module)
  • Java 责任链模式 减少 if else 实战案例
  • RabbitMQ高效的消息队列中间件原理及实践
  • SQL,力扣题目1127, 用户购买平台
  • 触想强固型工业显示器加速海上油气勘探开发
  • GIT版本控制与协同开发
  • pnpm快速入门
  • [000-01-008].第01节:Consul环境搭建
  • 【蓝桥杯集训100题】scratch绘制扇子 蓝桥杯scratch比赛专项预测编程题 集训模拟练习题第28题
  • 从零开始掌握Vue实例
  • 7,sql 基本的创建库表查询数据
  • 设计模式-抽象工厂 abstract_factory
  • 【网络安全】漏洞挖掘
  • springboot启动很慢,加载xml时卡住 或者 {dataSource-1} inited卡住 或者 primary数据库配置错误,很久启动不起来
  • 美颜相机java
  • C# 以管理员方式启动
  • 注册免费的vps:infinityfree
  • Spring MVC概述
  • (三)Kafka离线安装 - ZooKeeper开机自启
  • 搭建自己的金融数据源和量化分析平台(八):解析PDF财报中的资产负债表
  • Power BI仪表盘与报告实施方案:让数据变得生动且有用!
  • 目标检测:Cascade R-CNN: Delving into High Quality Object Detection - 2017【方法解读】
  • 【解析几何笔记】12.向量的混合积及其应用
  • 51单片机——数码管控制