BGRToYCbCr420
将图像模型由BGR格式转换为YCbCr格式,采样格式为4:2:0。依据采样方式,其中roiSize的宽和高需为2的倍数,否则,将roiSize的值修正到最近的2的倍数以后,再进行计算,并返回告警信息。
计算公式如下:
Y = 0.257*R + 0.504*G + 0.098*B + 16
Cb = -0.148*R - 0.291*G + 0.439*B + 128
Cr = 0.439*R - 0.368*G - 0.071*B + 128
函数接口声明如下:
HmppResult HMPPI_BGRToYCbCr420_8u_C3P3R(const uint8_t* src, int32_t srcStep, uint8_t* dst[3], int32_t dstStep[3], HmppiSize roiSize);
HmppResult HMPPI_BGRToYCbCr420_8u_AC4P3R(const uint8_t* src, int32_t srcStep, uint8_t* dst[3], int32_t dstStep[3], HmppiSize roiSize);
参数
参数名  | 
描述  | 
取值范围  | 
输入/输出  | 
|---|---|---|---|
src  | 
指向源向量的指针。  | 
非空  | 
输入  | 
srcStep  | 
源图像中连续行起点之间的距离(以字节为单位)。  | 
(0, INT_MAX]  | 
输入  | 
dst  | 
指向目的向量的指针。  | 
非空  | 
输出  | 
dstStep  | 
目标图像中连续行的起点之间的距离(以字节为单位)。  | 
(0, INT_MAX]  | 
输入  | 
roiSize  | 
源和目标图像感兴趣区域的大小(以像素为单位)。  | 
roiSize.width∈(0, INT_MAX],roiSize.height∈(0, INT_MAX]  | 
输入  | 
返回值
- 成功:返回HMPP_STS_NO_ERR。
 - 失败:返回错误码。
 
错误码
错误码  | 
描述  | 
|---|---|
HMPP_STS_NULL_PTR_ERR  | 
src、dst这两个入参中存在空指针。  | 
HMPP_STS_SIZE_ERR  | 
roiSize.width、roiSize.height这两个入参中存在值小于2。  | 
HMPP_STS_STEP_ERR  | 
srcStep、dstStep小于等于0。  | 
HMPP_STS_ROI_ERR  | 
roiSize.width > 步长。  | 
HMPP_STS_DOUBLE_SIZE  | 
告警码,roiSize.width、roiSize.height这两个入参中存在值不是2的倍数。  | 
示例
#define SRC_BUFFER_SIZE_T 90
#define DST_BUFFER_SIZE_T 12
int CopyExample()
{
    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
    };
    uint8_t a[DST_BUFFER_SIZE_T], b[DST_BUFFER_SIZE_T], c[DST_BUFFER_SIZE_T];
    uint8_t *dst[3] = {a, b, c};
    int32_t srcStep = 15 * sizeof(uint8_t);
    int32_t dstStep[3] = {12 * sizeof(uint8_t),12 * sizeof(uint8_t),12 * sizeof(uint8_t)};
    HmppResult result = HMPPI_BGRToYCbCr420_8u_C3P3R(src, srcStep, dst, dstStep, roi);
    printf("result = %d \ndst = ", result);
    if (result != HMPP_STS_NO_ERR) {
        printf("result error: %d\n", result);
    }
    for(int32_t i = 0; i < 3; i++){
        int32_t dstWidth = dstStep[i] / sizeof(uint8_t);
        for (int32_t j = 0; j < DST_BUFFER_SIZE_T; j++) {
            if( j % dstWidth == 0 ){
                printf("\n");
            }
            printf("%3d ",dst[i][j]);       
        }
    }
    printf("\n");
    return 0;
}
运行结果:
result = 0 dst = 37 65 74 80 0 0 0 0 0 0 0 0 121 133 0 0 0 0 0 0 0 0 0 0 133 111 0 0 0 0 0 0 0 0 0 0