libfreerdp-primitives: update YCbCr color converter

This commit is contained in:
Marc-André Moreau 2014-09-08 12:28:35 -04:00
parent ad9092baf9
commit cc16ddea2d
2 changed files with 73 additions and 6 deletions

View File

@ -51,13 +51,13 @@ pstatus_t general_yCbCrToRGB_16s8u_P3AC4R(const INT16* pSrc[3], int srcStep,
{ {
for (x = 0; x < roi->width; x++) for (x = 0; x < roi->width; x++)
{ {
Y = (double) ((*pY++ >> 1) + 2048); Y = (double) (pY[0] + 4096);
Cb = (double) (*pCb++ >> 1); Cb = (double) (pCb[0]);
Cr = (double) (*pCr++ >> 1); Cr = (double) (pCr[0]);
R = (INT16) (((int) (Y + (1.402524948120117L * Cr) + 8.0L)) >> 4); R = ((INT16) (((Cr * 1.402524948120117L) + Y + 16.0L)) >> 5);
G = (INT16) (((int) (Y - (0.3437300026416779L * Cb) - (0.7144010066986084L * Cr) + 8.0L)) >> 4); G = ((INT16) ((Y - (Cb * 0.3437300026416779L) - (Cr * 0.7144010066986084L) + 16.0L)) >> 5);
B = (INT16) (((int) (Y + (1.769904971122742L * Cb) + 8.0L)) >> 4); B = ((INT16) (((Cb * 1.769904971122742L) + Y + 16.0L)) >> 5);
if (R < 0) if (R < 0)
R = 0; R = 0;
@ -78,6 +78,10 @@ pstatus_t general_yCbCrToRGB_16s8u_P3AC4R(const INT16* pSrc[3], int srcStep,
*pRGB++ = (BYTE) G; *pRGB++ = (BYTE) G;
*pRGB++ = (BYTE) R; *pRGB++ = (BYTE) R;
*pRGB++ = 0xFF; *pRGB++ = 0xFF;
pY++;
pCb++;
pCr++;
} }
pY += srcPad; pY += srcPad;

View File

@ -2106,6 +2106,51 @@ static int test_memcmp_count(const BYTE* mem1, const BYTE* mem2, int size)
return count; return count;
} }
static void test_fill_bitmap_red_channel(BYTE* data, int width, int height, BYTE value)
{
int i, j;
UINT32* pixel;
for (i = 0; i < height; i++)
{
for (j = 0; j < width; j++)
{
pixel = (UINT32*) &data[((i * width) + j) * 4];
*pixel = ((*pixel & 0xFF00FFFF) | (value << 16));
}
}
}
static void test_fill_bitmap_green_channel(BYTE* data, int width, int height, BYTE value)
{
int i, j;
UINT32* pixel;
for (i = 0; i < height; i++)
{
for (j = 0; j < width; j++)
{
pixel = (UINT32*) &data[((i * width) + j) * 4];
*pixel = ((*pixel & 0xFFFF00FF) | (value << 8));
}
}
}
static void test_fill_bitmap_blue_channel(BYTE* data, int width, int height, BYTE value)
{
int i, j;
UINT32* pixel;
for (i = 0; i < height; i++)
{
for (j = 0; j < width; j++)
{
pixel = (UINT32*) &data[((i * width) + j) * 4];
*pixel = ((*pixel & 0xFFFFFF00) | (value));
}
}
}
int TestPrimitivesYCbCr(int argc, char* argv[]) int TestPrimitivesYCbCr(int argc, char* argv[])
{ {
int cmp; int cmp;
@ -2159,6 +2204,24 @@ int TestPrimitivesYCbCr(int argc, char* argv[])
_aligned_free(pSrcDst[2]); _aligned_free(pSrcDst[2]);
} }
if (0)
{
test_fill_bitmap_red_channel(actual, 64, 64, 0);
test_fill_bitmap_red_channel(expected, 64, 64, 0);
}
if (0)
{
test_fill_bitmap_green_channel(actual, 64, 64, 0);
test_fill_bitmap_green_channel(expected, 64, 64, 0);
}
if (0)
{
test_fill_bitmap_blue_channel(actual, 64, 64, 0);
test_fill_bitmap_blue_channel(expected, 64, 64, 0);
}
cmp = test_memcmp_offset(actual, expected, size); cmp = test_memcmp_offset(actual, expected, size);
cnt = test_memcmp_count(actual, expected, size); cnt = test_memcmp_count(actual, expected, size);