OpenCV 图形API(42)颜色空间转换-----将 BGR图像转换为 I420(YUV 4:2:0)格式函数BGR2I420()

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

算法描述

将图像从BGR色彩空间转换为I420色彩空间。

该函数将输入图像从BGR色彩空间转换为I420。R、G和B通道值的传统范围是0到255。

输出图像必须是8位无符号1通道图像。CV_8UC1。I420输出图像的宽度必须与输入图像的宽度相同。I420输出图像的高度必须等于输入图像高度的3/2。

cv::gapi::BGR2I420 是 OpenCV 的 G-API 模块中的一个函数,用于将 BGR(蓝绿红)颜色空间的图像转换为 I420(也称为 YUV 4:2:0)颜色格式。I420 格式是一种平面格式,其中亮度信息(Y)存储在一个平面上,而色度信息(U和V)分别以较低分辨率存储在另外两个平面上。

注意

函数的文字ID是 "org.opencv.imgproc.colorconvert.bgr2i420"

函数原型

cpp 复制代码
GMat cv::gapi::BGR2I420 	
(
 	const GMat &  	src
 ) 	

参数

  • 参数 src 输入图像:8位无符号3通道图像 CV_8UC3。

代码示例

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

int main()
{
    // 加载输入图像
    cv::Mat bgr_img = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/Lenna.png" );
    if ( bgr_img.empty() )
    {
        std::cerr << "无法读取图像,请检查路径是否正确。\n";
        return -1;
    }

    // 定义G-API网络
    cv::GMat in;
    cv::GMat yuv = cv::gapi::BGR2I420( in );

    // 创建并运行G-API图
    cv::GComputation comp( cv::GIn( in ), cv::GOut( yuv ) );

    // 准备接收输出的变量
    cv::Mat yuv_output;

    // 应用计算图
    comp.apply( bgr_img, yuv_output );

    // 现在我们需要手动将YUV420平面分离
    int height = bgr_img.rows;
    int width  = bgr_img.cols;

    // Y平面是完整分辨率
    cv::Mat y_plane( height, width, CV_8UC1, yuv_output.data );

    // U和V平面是1/4分辨率
    cv::Mat uv_plane( height / 2, width / 2, CV_8UC2, yuv_output.data + height * width );

    // 分离UV平面
    std::vector< cv::Mat > uv_channels;
    cv::split( uv_plane, uv_channels );
    cv::Mat u_plane = uv_channels[ 0 ];
    cv::Mat v_plane = uv_channels[ 1 ];

    // 显示或处理结果
    cv::imwrite( "y_plane.png", y_plane );
    cv::imwrite( "u_plane.png", u_plane );
    cv::imwrite( "v_plane.png", v_plane );

    return 0;
}
相关推荐
一点.点40 分钟前
SafeDrive:大语言模型实现自动驾驶汽车知识驱动和数据驱动的风险-敏感决策——论文阅读
人工智能·语言模型·自动驾驶
concisedistinct1 小时前
如何评价大语言模型架构 TTT ?模型应不应该永远“固定”在推理阶段?模型是否应当在使用时继续学习?
人工智能·语言模型·大模型
找了一圈尾巴1 小时前
AI Agent-基础认知与架构解析
人工智能·ai agent
jzwei0231 小时前
Transformer Decoder-Only 参数量计算
人工智能·深度学习·transformer
小言Ai工具箱1 小时前
PuLID:高效的图像变脸,可以通过文本提示编辑图像,通过指令修改人物属性,个性化文本到图像生成模型,支持AI变脸!艺术创作、虚拟形象定制以及影视制作
图像处理·人工智能·计算机视觉
白熊1881 小时前
【计算机视觉】基于深度学习的实时情绪检测系统:emotion-detection项目深度解析
人工智能·深度学习·计算机视觉
TextIn智能文档云平台1 小时前
PDF文档解析新突破:图表识别、公式还原、手写字体处理,让AI真正读懂复杂文档!
图像处理·人工智能·算法·自然语言处理·pdf·ocr
老任与码1 小时前
Spring AI(2)—— 发送消息的API
java·人工智能·spring ai
AI改变未来1 小时前
智慧城市新力量!AI如何助力社会治理创新?
人工智能·ai·智慧城市·ai应用
Panesle2 小时前
HunyuanCustom:文生视频框架论文速读
人工智能·算法·音视频·文生视频