YCbCrToBGR_709CSC
函数说明:
将YCbCr图像转换为BGR(ITU-R BT.709 CSC)颜色模型。
该函数将平面Y'Cb'Cr'图像转换为符合ITU-R BT.709建议【ITU709】的数字分量视频信号的三通道或四通道伽马校正B'G'R'图像用于计算机系统考虑(CSC)。根据以下公式【Jack01】进行转换:
输出R'G'B'值饱和到范围[0, 255]。
第四个通道是通过将通道值设置为常量值aval来创建的。
函数接口声明如下:
HmppResult HMPPI_YCbCrToBGR_709CSC_8u_P3C3R(const uint8_t *src[3], int32_t srcStep, uint8_t* dst, int32_t dstStep, HmppiSize roiSize);
HmppResult HMPPI_YCbCrToBGR_709CSC_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_YCbCrToBGR_709CSC() { HmppiSize roi = { 4, 4 }; const uint8_t src1[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 }; const uint8_t src2[SRC_BUFFER_SIZE_T] = { 11, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 21, 23, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 31, 24, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 41, 25, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 51, 26, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 61, 27, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33 }; const uint8_t src3[SRC_BUFFER_SIZE_T] = { 11, 12, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 12, 22, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 13, 32, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 14, 42, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 15, 52, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33, 16, 62, 33, 44, 55, 66, 77, 88, 22, 88, 77, 66, 55, 44, 33 }; const uint8_t *src[3] = {src1, src2, src3}; int32_t srcStep = 20 * sizeof(uint8_t); int32_t dstStep = 20 * sizeof(uint8_t);; uint8_t dst[DST_BUFFER_SIZE_T] = {0}; uint8_t aval = 254; HmppResult result = HMPPI_YCbCrToBGR_709CSC_8u_P3C4R(src, srcStep, dst, dstStep, roi, aval); 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_YCbCrToBGR_709CSC(); return 0; }
运行结果:
result = 0 dst = 0 82 0 254 0 92 0 254 0 91 0 254 0 95 0 254 0 0 0 0 0 105 0 254 0 109 0 254 0 114 12 254 0 86 0 254 0 0 0 0 0 109 0 254 0 105 0 254 0 100 0 254 0 95 0 254 0 0 0 0 0 71 0 254 0 69 0 254 0 91 0 254 0 95 0 254 0 0 0 0 0 0 0 0 0 0 0 0 0 0