YCbCrToBGR
函数说明:
将YCbCr图像转换为BGR颜色模型。
此函数根据与函数YCbCrToRGB相同的公式,将Y'Cb'Cr'图像转换为24位伽马校正的B'G'R'图像。输出B'G'R'值饱和到范围[0, 255]。
第四个通道是通过将通道值设置为常量值aval来创建的。
函数接口声明如下:
HmppResult HMPPI_YCbCrToBGR_8u_P3C3R(const uint8_t *src[3], int32_t srcStep, uint8_t *dst, int32_t dstStep, HmppiSize roiSize);
HmppResult HMPPI_YCbCrToBGR_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() { 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 = 25; HmppResult result = HMPPI_YCbCrToBGR_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(); return 0; }
运行结果:
result = 0 dst = 0 135 0 25 0 143 0 25 0 134 0 25 0 134 0 25 0 0 0 0 0 133 0 25 0 133 0 25 3 132 20 25 0 135 0 25 0 0 0 0 0 133 0 25 0 133 0 25 0 133 0 25 0 134 0 25 0 0 0 0 0 116 0 25 0 109 0 25 0 134 0 25 0 134 0 25 0 0 0 0 0 0 0 0 0 0 0 0 0 0