【genius_platform软件平台开发】第七十五讲:YUY2转RGB24实现源码

本文主要是介绍【genius_platform软件平台开发】第七十五讲:YUY2转RGB24实现源码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

YUY2转RGB24实现源码

  • 1. 实现源码
  • 2. 测试文件

  • 今日在对接大力ir红外sensor时,需要对前半部分YUV422的伪彩图像数据进行RGB24转换,源码可以实现转RGB24或者BGR24,部分函数可以删除掉,只关注重点转换函数即可

1. 实现源码

  • Yuy2FrameProcess.h
#ifndef __YUY2_FRAME_PROCESS_H__
#define __YUY2_FRAME_PROCESS_H__#include "OLeiIrFrameDef.h"
#include "Stream/GpIrFrameProcess.h"//
// yuv420数据流处理类
class CYuy2FrameProcess : public CGpIrFrameProcess
{
public:CYuy2FrameProcess();virtual ~CYuy2FrameProcess();// yuy2图像数据到rgb24图像数据转换INT32 yuy2ToRgb24Convert(unsigned char* pSrc, unsigned char* pDst, int nImageWidth, int nImageHeight);// yuy2图像数据到bgr24图像数据转换INT32 yuy2ToBgr24Convert(unsigned char* pSrc, unsigned char* pDst, int nImageWidth, int nImageHeight);public:// 帧处理函数(目前与IR流处理没有差异)virtual INT32 ProcessFrame(void* pData = NULL);
};
#endif //__YUY2_FRAME_PROCESS_H__
  • Yuy2FrameProcess.cpp
#include "Yuy2FrameProcess.h"
#include "Base/Thread/GpFrameProcessThread.h"
#include "Stream/GpFrameProcessCenter.h"
#include "Stream/Gpts/Yuy2FrameDef.h"//
//
CYuy2FrameProcess::CYuy2FrameProcess()
{LOGMSG("CYuy2FrameProcess::CYuy2FrameProcess");// 等待耗时统计TimePoint nTotalCostTm = currentTime();// 设置typethis->setType(FrameProcessType_Yuv420);LOGMSG("CYuy2FrameProcess::CYuy2FrameProcess is suc... nTotalCostTm=[%u]", (currentTime() - nTotalCostTm).count());
}//
//
CYuy2FrameProcess::~CYuy2FrameProcess()
{LOGMSG("CYuy2FrameProcess::~CYuy2FrameProcess");// 等待耗时统计TimePoint nTotalCostTm = currentTime();// 释放线程资源this->releaseFrameProcThread();LOGMSG("CYuy2FrameProcess::~CYuy2FrameProcess is suc... nTotalCostTm=[%llu]", (currentTime() - nTotalCostTm).count());
}//
// 处理数据流
INT32 CYuy2FrameProcess::ProcessFrame(void *pData)
{CGpFrameProcessThread* pThread = static_cast<CGpFrameProcessThread*>(pData);CHECKI(pThread);CHECKF(m_pFrameProcessCenter);CGpFrame* pFrame = this->takeFirst();if (!pFrame || pFrame->isEmpty()){// 阻塞等待,后续有空时测试下效率/** 1.锁导致上下文切换开销很大,导致帧率30~10帧*///std::unique_lock<std::mutex> ulock(m_Mtx);//m_Cond.wait(ulock);msSleep(10);return ReturnCode_Empty;}GpFrameType frameType = pFrame->getFrameType();CHECKI(frameType == FRAME_TYPE_EXT_IR);int nConvertFormat = CONVERT_FORMAT_RGB24;// 计算所需内存大小(w * h * 3) 每个像素点3通道int nRgb24Size = pFrame->getWidth() * pFrame->getHeight() * 3;// 构造ir数据帧CGpFrame* pRgb24Frame = new CGpFrame(nRgb24Size);if (pRgb24Frame == NULL){LOGERROR("CYuy2FrameProcess::ProcessFrame new CGpFrame pRgb24Frame is NULL");goto delete_frame;}pRgb24Frame->setBlockId(pFrame->getBlockId());pRgb24Frame->setNetCode(pFrame->getNetCode());   pRgb24Frame->setCompressType(DATA_COMPRESS_RAW);pRgb24Frame->setFrameType(FRAME_TYPE_RGB24);pRgb24Frame->setWidth(pFrame->getWidth());pRgb24Frame->setHeight(pFrame->getHeight());pRgb24Frame->setChannelIndex(pFrame->getChannelIndex());pRgb24Frame->setFrameCount(pFrame->getFrameCount());pRgb24Frame->setTimestamp(pFrame->getTimestamp());// 生产rgb或者bgrif (nConvertFormat == CONVERT_FORMAT_RGB24){// yuy2图像数据到rgb24图像数据转换this->yuy2ToRgb24Convert((unsigned char*)pFrame->getData(), (unsigned char*)pRgb24Frame->getData(), pFrame->getWidth(), pFrame->getHeight());}else if (nConvertFormat == CONVERT_FORMAT_BGR24){// yuy2图像数据到bgr24图像数据转换this->yuy2ToRgb24Convert((unsigned char*)pFrame->getData(), (unsigned char*)pRgb24Frame->getData(), pFrame->getWidth(), pFrame->getHeight());}else{LOGERROR("CYuy2FrameProcess::yuy2ToRgb24Convert nConvertFormat is error... nConvertFormat=[%d]", nConvertFormat);goto delete_frame;}CGpFrameProcessCenter* pFrameProcessCenter = dynamic_cast<CGpFrameProcessCenter*>(this->getFrameProcessCenter());if (pFrameProcessCenter == NULL){LOGERROR("CYuy2FrameProcess::ProcessFrame pFrameProcessCenter is NULL");goto delete_frame;}// 送数据处理pFrameProcessCenter->outputFrame(pRgb24Frame);delete_frame:// 释放pIrFrameSAFE_DELETE(pFrame);// 释放pRgb24FrameSAFE_DELETE(pRgb24Frame);return ReturnCode_Success;
}//
// yuy2图像数据到rgb24图像数据转换
// 原文链接:https://blog.csdn.net/tong5956/article/details/112037131
INT32 CYuy2FrameProcess::yuy2ToRgb24Convert(unsigned char* pSrc, unsigned char* pDst, int nImageWidth, int nImageHeight)
{CHECKI(pSrc);CHECKI(pDst);CHECKI(nImageWidth > 0);CHECKI(nImageHeight > 0);// 获取yuyv数据指针unsigned char* pYuyvData = pSrc;int z = 0;int i = 0;int j = 0;for (i = 0; i < nImageHeight; i++) {for (j = 0; j < nImageWidth; j++) {int r, g, b;int y, u, v;// YUYV格式if (!z){y = pYuyvData[0] << 8;}else{y = pYuyvData[2] << 8;}u = pYuyvData[1] - 128;v = pYuyvData[3] - 128;// yuv分量到rgb分量转换r = (y + (359 * v)) >> 8;g = (y - (88 * u) - (183 * v)) >> 8;b = (y + (454 * u)) >> 8;// 如果溢出>255或者小于0r = (r > 255) ? 255 : ((r < 0) ? 0 : r);g = (g > 255) ? 255 : ((g < 0) ? 0 : g);b = (b > 255) ? 255 : ((b < 0) ? 0 : b);// 转换出来是rgb图像*pDst++ = r;*pDst++ = g;*pDst++ = b;// 执行0/1重置和数据指针偏移if (z++) {z = 0;pYuyvData += 4;}}}return ReturnCode_Success;
}//
// yuy2图像数据到bgr24图像数据转换
INT32 CYuy2FrameProcess::yuy2ToBgr24Convert(unsigned char* pSrc, unsigned char* pDst, int nImageWidth, int nImageHeight)
{CHECKI(pSrc);CHECKI(pDst);CHECKI(nImageWidth > 0);CHECKI(nImageHeight > 0);// 获取yuyv数据指针unsigned char* pYuyvData = pSrc;int z = 0;int i = 0;int j = 0;for (i = 0; i < nImageHeight; i++){for (j = 0; j < nImageWidth; j++){int r, g, b;int y, u, v;// YUYV格式if (!z){y = pYuyvData[0] << 8;}else{y = pYuyvData[2] << 8;}u = pYuyvData[1] - 128;v = pYuyvData[3] - 128;// yuv分量到rgb分量转换r = (y + (359 * v)) >> 8;g = (y - (88 * u) - (183 * v)) >> 8;b = (y + (454 * u)) >> 8;// 如果溢出>255或者小于0r = (r > 255) ? 255 : ((r < 0) ? 0 : r);g = (g > 255) ? 255 : ((g < 0) ? 0 : g);b = (b > 255) ? 255 : ((b < 0) ? 0 : b);// 转换出来是bgr图像*pDst++ = b;*pDst++ = g;*pDst++ = r;// 执行0/1重置和数据指针偏移if (z++){z = 0;pYuyvData += 4;}}}return ReturnCode_Success;
}

2. 测试文件

  • 执行程序生产2个test_rgb24.bin和test_bgr24.bin文件,使用软件平台离线工具播放显示正确无误;
    在这里插入图片描述
    在这里插入图片描述

这篇关于【genius_platform软件平台开发】第七十五讲:YUY2转RGB24实现源码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/154656

相关文章

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方