EN
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助

YCbCrToRGB

函数说明:

将YCbCr图像转换为RGB颜色模型。

此函数将Y'Cb'Cr'图像src转换为24位伽马校正的R'G'B'图像dst。转换使用以下公式:

R' = 1.164*(Y' - 16) + 1.596*(Cr' - 128)

G' = 1.164*(Y' - 16) - 0.813*(Cr' - 128) - 0.392*(Cb' - 128)

B' = 1.164*(Y' - 16) + 2.017*(Cb' - 128)

输出R'G'B'值饱和到范围[0,255]。

第四个通道是通过将通道值设置为常量值aval来创建的

函数接口声明如下:

  • 对像素阶数据的操作:

    HmppResult HMPPI_YCbCrToRGB_8u_C3R(const uint8_t* src, int32_t srcStep, uint8_t *dst, int32_t dstStep, HmppiSize roiSize);

    HmppResult HMPPI_YCbCrToRGB_8u_AC4R(const uint8_t* src, int32_t srcStep, uint8_t *dst, int32_t dstStep, HmppiSize roiSize);

  • 对平面数据的操作:

    HmppResult HMPPI_YCbCrToRGB_8u_P3R(const uint8_t* src[3], int32_t srcStep, uint8_t *dst[3], int32_t dstStep, HmppiSize roiSize);

    HmppResult HMPPI_YCbCrToRGB_8u_P3C3R(const uint8_t* src[3], int32_t srcStep, uint8_t *dst, int32_t dstStep, HmppiSize roiSize);

  • 从平面到像素阶数据的转换:

    HmppResult HMPPI_YCbCrToRGB_8u_P3C4R(const uint8_t* src[3], int32_t srcStep, uint8_t *dst, int32_t dstStep, HmppiSize roiSize, uint8_t aval);

参数

参数名

描述

取值范围

输入/输出

src

指向源图像的指针。该数组存储指向源平面图像的颜色平面的指针。

非空

输入

srcStep

源图像中连续行的起点之间的距离(以字节为单位)。

非负整数

输入

dst

指向目的图像感兴趣区域的指针。该数组存储指向目标平面图像的颜色平面的指针。

非空

输出

dstStep

目标图像中连续行的起点之间的距离(以字节为单位)。

非负整数

输入

roiSize

源和目标图像感兴趣区域的大小(以像素为单位)。

roiSize.width∈(0, INT_MAX],roiSize.height∈(0, INT_MAX]

输入/输出

aval

创建第四个通道的常量值。

非负整数

输入

返回值

  • 成功:返回HMPP_STS_NO_ERR
  • 失败:返回错误码。

错误码

错误码

描述

HMPP_STS_NULL_PTR_ERR

src中存在空指针。

HMPP_STS_SIZE_ERR

roiSize的字段为零或负值。

HMPP_STS_STEP_ERR

srcStep中存在零或负值。

HMPP_STS_ROI_ERR

roiSize的width与通道数乘积大于步长srcStep。

示例

#define SRC_BUFFER_SIZE_T 90
#define DST_BUFFER_SIZE_T 90

void TestExample_YCbCrToRGB()
{
    HmppiSize roi = { 4, 4 };
    const uint8_t src[SRC_BUFFER_SIZE_T] = {
        11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33,
        11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33,
        11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33,
        11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33,
        11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33,
        11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33
    };
    int32_t srcStep = 20 * sizeof(uint8_t);
    int32_t dstStep = 15 * sizeof(uint8_t);;
    uint8_t dst[DST_BUFFER_SIZE_T] = {0};

    HmppResult result = HMPPI_YCbCrToRGB_8u_C3R(src, srcStep, dst, dstStep, roi);

    printf("result = %d \ndst = ", result);
    if (result != HMPP_STS_NO_ERR) {
        printf("result error: %d\n", result);
    }
    int32_t dstWidth = dstStep / sizeof(uint8_t);
    for(int32_t i = 0; i < DST_BUFFER_SIZE_T; i++){
        if (i % dstWidth == 0) {
            printf("\n");
        }
        printf("%3d ",dst[i]);
    }
    printf("\n");

}

int main()
{
   TestExample_YCbCrToRGB();
}

运行结果:

result = 0
dst =
  0 113   0   0 112   0   0 173   0   0 154   0   0   0   0
  0 111   0   0  64   0   0 155   0   0 152   0   0   0   0
  0 155   0   0 165   0   0 113   0   0 111   0   0   0   0
  0 113   0   0 112   0   0 173   0   0 154   0   0   0   0
  0   0   0   0   0   0   0   0   0   0   0   0   0   0   0
  0   0   0   0   0   0   0   0   0   0   0   0   0   0   0