OpenCV 图形API(74)图像与通道拼接函数-----合并三个单通道图像(GMat)为一个多通道图像的函数merge3()

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

算法描述

从3个单通道矩阵创建一个3通道矩阵。

此函数将多个矩阵合并以生成一个单一的多通道矩阵。即,输出矩阵的每个元素将是输入矩阵元素的串联,其中第i个输入矩阵的元素被视为mv[i].channels()元素向量。输出矩阵必须是CV_8UC3类型。

split3函数执行相反的操作。

注意:

函数的文字ID是"org.opencv.core.transform.merge3"

函数原型

cpp 复制代码
GMat cv::gapi::merge3 	
(
 	const GMat &  	src1,
	const GMat &  	src2,
	const GMat &  	src3 
) 		

参数

  • 参数 src1:第一个输入的CV_8UC1类型的矩阵,需要被合并。
  • 参数 src2:第二个输入的CV_8UC1类型的矩阵,需要被合并。
  • 参数 src3:第三个输入的CV_8UC1类型的矩阵,需要被合并。

代码示例

cpp 复制代码
#include <opencv2/gapi.hpp>
#include <opencv2/gapi/core.hpp>
#include <opencv2/opencv.hpp>

int main()
{
    // 设置图像路径
    std::string imagePath = "/media/dingxin/data/study/OpenCV/sources/images/Lenna.png";

    // 加载图像
    cv::Mat src = cv::imread( imagePath, cv::IMREAD_COLOR );
    if ( src.empty() )
    {
        std::cerr << "Failed to load image!" << std::endl;
        return -1;
    }

    // 分离三个通道
    std::vector< cv::Mat > channels;
    cv::split( src, channels );

    // 检查分离出的通道数量是否正确
    if ( channels.size() != 3 )
    {
        std::cerr << "Expected 3 channels, but got " << channels.size() << std::endl;
        return -1;
    }

    // 定义输入节点(三个单通道图像)
    cv::GMat g_b, g_g, g_r;

    // 定义 G-API 图操作:合并三个通道为一个三通道图像
    cv::GMat g_merged = cv::gapi::merge3( g_b, g_g, g_r );

    // 构建 GComputation(定义整个计算图)
    cv::GComputation comp( cv::GIn( g_b, g_g, g_r ), cv::GOut( g_merged ) );

    // 输出图像容器
    cv::Mat out;

    // 正确调用 apply:将输入输出包装为 vector
    std::vector< cv::Mat > inputs  = { channels[ 0 ], channels[ 1 ], channels[ 2 ] };
    std::vector< cv::Mat > outputs = { out };

    // 执行 GComputation
    comp.apply( inputs, outputs, cv::compile_args() );

    // 获取真正的输出图像
    out = outputs[ 0 ];

    // 检查输出是否为空或者无效大小
    if ( out.empty() )
    {
        std::cerr << "Error: Merged output image is empty!" << std::endl;
        return -1;
    }
    if ( out.rows <= 0 || out.cols <= 0 )
    {
        std::cerr << "Error: Merged output image has invalid size: " << out.cols << "x" << out.rows << std::endl;
        return -1;
    }

    // 显示原图和合并后的图像
    cv::imshow( "Original Image", src );
    cv::imshow( "Merged Image (G-API)", out );
    cv::waitKey( 0 );

    return 0;
}

运行结果

相关推荐
德育处主任Pro7 分钟前
『React』 组件通信全攻略
python·opencv·matplotlib
格林威22 分钟前
Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现道路汽车的检测识别(C#代码,UI界面版)
人工智能·深度学习·数码相机·yolo·视觉检测
欧阳小猜33 分钟前
机器学习②【字典特征提取、文本特征处理(TF-IDF)、数据标准化与归一化、特征降维】
人工智能·机器学习·tf-idf
电商数据girl40 分钟前
如何利用API接口与网页爬虫协同进行电商平台商品数据采集?
大数据·开发语言·人工智能·python·django·json
8Qi81 小时前
深度学习(鱼书)day08--误差反向传播(后三节)
人工智能·python·深度学习·神经网络
wow_DG2 小时前
【PyTorch✨】01 初识PyTorch
人工智能·pytorch·python
海绵波波1072 小时前
解读LISA:通过大型语言模型实现推理分割
人工智能·语言模型·自然语言处理
昨日之日20062 小时前
FLUX.1 Kontext Dev V2版 - 消费级显卡(6G显存)畅玩的AI修图神器 支持批量 支持多图融合编辑 支持50系显卡 一键整合包下载
人工智能
海森大数据2 小时前
神经网络“开窍”时刻:从死记位置到理解意义的语言奇点
人工智能·深度学习·神经网络
贾全2 小时前
Transformer架构全解析:搭建AI的“神经网络大厦“
人工智能·神经网络·ai·语言模型·自然语言处理·架构·transformer