繁体   English   中英

显示RGB888内容

[英]Show RGB888 content

我必须使用ShowRGBContent函数显示RGB888内容。

以下函数是yv12-> rgb565UYVY-> RGB565ShowRGBContent函数

static void ShowRGBContent(UINT8 * pImageBuf, INT32 width, INT32 height) 
{
LogEntry(L"%d : In %s Function \r\n",++abhineet,__WFUNCTION__);
UINT16 * temp;
BYTE rValue, gValue, bValue;

// this is to refresh the background desktop
ShowWindow(GetDesktopWindow(),SW_HIDE);
ShowWindow(GetDesktopWindow(),SW_SHOW); 

for(int i=0; i<height; i++)
{
 for (int j=0; j< width; j++)        
 {
  temp = (UINT16 *) (pImageBuf+ i*width*PP_TEST_FRAME_BPP+j*PP_TEST_FRAME_BPP);
  bValue = (BYTE) ((*temp & RGB_COMPONET0_MASK) >> RGB_COMPONET0_OFFSET) << (8 -RGB_COMPONET0_WIDTH);
  gValue = (BYTE) ((*temp & RGB_COMPONET1_MASK) >> RGB_COMPONET1_OFFSET) << (8 -RGB_COMPONET1_WIDTH);
  rValue = (BYTE) ((*temp & RGB_COMPONET2_MASK) >> RGB_COMPONET2_OFFSET) << (8 -RGB_COMPONET2_WIDTH);            
  SetPixel(g_hDisplay, SCREEN_OFFSET_X + j, SCREEN_OFFSET_Y+i, RGB(rValue, gValue, bValue));
 }
}

Sleep(2000); //sleep here to review the result

LogEntry(L"%d :Out %s Function \r\n",++abhineet,__WFUNCTION__);
}

我必须为RGB888修改它

在上面的功能中:

************************
RGB_COMPONET0_WIDTH = 5
RGB_COMPONET1_WIDTH = 6
RGB_COMPONET2_WIDTH = 5
************************

************************
RGB_COMPONET0_MASK = 0x001F //31 in decimal
RGB_COMPONET1_MASK = 0x07E0 //2016 in decimal
RGB_COMPONET2_MASK = 0xF800 //63488 in decimal
************************

************************
RGB_COMPONET0_OFFSET = 0
RGB_COMPONET1_OFFSET = 5
RGB_COMPONET2_OFFSET = 11
************************

************************
SCREEN_OFFSET_X = 100
SCREEN_OFFSET_Y = 0
************************

Here 
Also PP_TEST_FRAME_BPP = 2 for yv12 -> RGB565 & UYVY -> RGB565

iOutputBytesPerFrame = iOutputStride * iOutputHeight; 
// where iOutputStride = (iOutputWidth * PP_TEST_FRAME_BPP) i.e (112 * 2)  
// & iOutputHeight = 160 
// These are in case of RGB565

pOutputFrameVirtAddr = (UINT32 *) AllocPhysMem( iOutputBytesPerFrame, 
                                                PAGE_EXECUTE_READWRITE, 
                                                0,
                                                0,
                                                (ULONG *) &pOutputFramePhysAddr); 

// PAGE_EXECUTE_READWRITE = 0x40 mentioned in winnt.h

// Width =112 & Height = 160 in all the formats for i/p & o/p

现在我的任务是为RGB888。 请指导我该怎么做。 **提前致谢。

从yuv444到rgb888的转换非常简单,因为所有组件都位于字节边界上,因此甚至不需要位屏蔽。 根据注释部分中提到的Wikipedia文章 nobugz,可以通过以下方式在固定点完成转换:

UINT8* pimg = pImageBuf;
for(int i=0; i<height; i++)
{
    for (int j=0; j< width; j++)        
    {
        INT16 Y = pimg[0];
        INT16 Cb = (INT16)pimg[1] - 128;
        INT16 Cr = (INT16)pimg[2] - 128;
        rValue = Y + Cr + Cr >> 2 + Cr >> 3 + Cr >> 5
        gValue = Y - (Cb >> 2 + Cb >> 4 + Cb >> 5) -
                 (Cr >> 1 + Cr >> 3 + Cr >> 4 + Cr >> 5);
        bValue = Y + Cb + Cb >> 1 + Cb >> 2 + Cb >> 6;
        SetPixel(g_hDisplay, SCREEN_OFFSET_X + j, SCREEN_OFFSET_Y+i, RGB(rValue,
                 gValue, bValue));
        pimg+=3;
    }
}

假设您的yuv444是每个样本8位(每个像素24位)。 转换也可以在浮点数中完成,但是如果它可行,则应该更快,因为您的源和目标都是固定点。 我也不确定是否需要转换为int16,但是我这样做是为了安全。

请注意,yuv444中的444与rgb888中的888所指的不是同一事物。 444是指使用TUV色彩空间时经常发生的二次采样。 例如,在YUV420中,Cb和Cr在两个方向上都被抽取了两个。 yuv444只是意味着对所有三个分量都进行了相同的采样(没有二次采样)。 rgb888中的888指的是每个样本的位(三个颜色分量中的每个8位)。

我没有实际测试过此代码,但是它至少应该让您知道从哪里开始。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM