OpenCV 图形API(67)图像与通道拼接函数-----水平拼接(横向连接)两个输入矩阵(GMat 类型)函数concatHor()

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

算法描述

该函数用于水平拼接两个 GMat 矩阵,要求输入矩阵的行数必须一致:

cpp 复制代码
GMat A = { 1, 4,
           2, 5,
           3, 6 };
GMat B = { 7, 10,
           8, 11,
           9, 12 };
GMat C = gapi::concatHor(A, B);
//C:
//[1, 4, 7, 10;
// 2, 5, 8, 11;
// 3, 6, 9, 12]

输出矩阵的行数和数据类型必须与 src1 和 src2 相同,其列数为 src1 和 src2 列数之和。支持的矩阵数据类型包括:CV_8UC1、CV_8UC3、CV_16UC1、CV_16SC1、CV_32FC1。

注意

该函数的文本标识符为 "org.opencv.imgproc.transform.concatHor"。

参数

  • 参数 src1:第一个输入矩阵(参与水平拼接)。

  • 参数 src2:第二个输入矩阵(参与水平拼接)。

返回值

返回一个新的 GMat,表示水平拼接后的结果。

代码示例

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

int main()
{
    // 读取图像(确保尺寸和类型匹配)
    cv::Mat mat1 = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/stich1.png", cv::IMREAD_COLOR );
    cv::Mat mat2 = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/stich2.png", cv::IMREAD_COLOR );

    if ( mat1.empty() || mat2.empty() )
    {
        std::cerr << "无法加载图像!" << std::endl;
        return -1;
    }

    // 强制统一尺寸和类型(G-API不会自动调整)
    if ( mat1.rows != mat2.rows )
    {
        cv::resize( mat2, mat2, cv::Size( mat2.cols, mat1.rows ) );
    }
    if ( mat1.type() != mat2.type() )
    {
        mat2.convertTo( mat2, mat1.type() );
    }

    // 构建G-API计算图
    cv::GMat in1, in2;
    cv::GMat out = cv::gapi::concatHor( in1, in2 );
    cv::GComputation comp( cv::GIn( in1, in2 ), cv::GOut( out ) );

    // 执行计算图
    cv::Mat result;
    comp.apply( cv::gin( mat1, mat2 ), cv::gout( result ) );

    cv::imshow( "G-API拼接结果", result );
    cv::waitKey( 0 );
    return 0;
}

运行结果

相关推荐
无心水1 小时前
【分布式利器:腾讯TSF】10、TSF故障排查与架构评审实战:Java架构师从救火到防火的生产哲学
java·人工智能·分布式·架构·限流·分布式利器·腾讯tsf
小鸡吃米…7 小时前
机器学习 - K - 中心聚类
人工智能·机器学习·聚类
好奇龙猫8 小时前
【AI学习-comfyUI学习-第三十节-第三十一节-FLUX-SD放大工作流+FLUX图生图工作流-各个部分学习】
人工智能·学习
沈浩(种子思维作者)8 小时前
真的能精准医疗吗?癌症能提前发现吗?
人工智能·python·网络安全·健康医疗·量子计算
saoys8 小时前
Opencv 学习笔记:图像掩膜操作(精准提取指定区域像素)
笔记·opencv·学习
minhuan8 小时前
大模型应用:大模型越大越好?模型参数量与效果的边际效益分析.51
人工智能·大模型参数评估·边际效益分析·大模型参数选择
Cherry的跨界思维8 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
MM_MS8 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
ASF1231415sd9 小时前
【基于YOLOv10n-CSP-PTB的大豆花朵检测与识别系统详解】
人工智能·yolo·目标跟踪
水如烟9 小时前
孤能子视角:“意识“的阶段性回顾,“感质“假说
人工智能