RGB888 到 RGB565 / 位移
Posted
技术标签:
【中文标题】RGB888 到 RGB565 / 位移【英文标题】:RGB888 to RGB565 / Bit Shifting 【发布时间】:2012-07-13 13:05:49 【问题描述】:我想使用位移将三个字符组合成一个短字符。这是为了实现 RGB565 调色板(红色 5 位,绿色 6 位,蓝色 5 位)。
这是我的示例程序,我只是在中间错过了一个步骤,我认为我需要做一些操作。
#include <stdio.h>
int main( )
unsigned char r, g, b;
unsigned short rgb;
r = 255; // 0xFF 1111 1111
g = 100; // 0x64 0110 0100
b = 50; // 0x32 0011 0010
r = r >> 3; // 0x31 0001 1111
g = g >> 2; // 0x19 0001 1001
b = b >> 3; // 0x06 0000 0110
//r = r & something; //
//g = g & something; //
//b = b & something; //
// Desired result:
// R G B
// 0xFB26 11111 011001 00110
rgb = r | g | b;
printf( "r 0x%x g 0x%x b 0x%x, rgb 0x%08x\n", r, g, b, rgb );
你可以在最后看到我想要的结果。感谢您的帮助!
【问题讨论】:
【参考方案1】:rgb = ((r & 0b11111000) << 8) | ((g & 0b11111100) << 3) | (b >> 3);
我们将r
左移 11 位,g
左移 5 位,然后将它们与b
右移 3 位按位或。 (注意:这假设值已经被正确屏蔽,如果需要,以删除任何不需要的位。)
【讨论】:
这似乎不对,| b
部分。 b
是 8 位,但您只需要附加其中的 5 个最高有效位。应该类似于| (b >> 3)
@VioletGiraffe:是的,我认为您可能是对的 - 我不确定为什么这是公认的答案 - 看起来我没有正确阅读问题或其他什么。无论如何,请随时编辑和更正它。
其实另外两个移位值也是错误的。有趣的是,我在我的项目中犯了同样的错误。一直想知道我的颜色有什么问题,然后我来这里验证我的公式是否正确,并且由于我们的公式匹配,我得出的结论是错误在其他地方:)
再次感谢您修复此答案 - 它通常是最简单的代码,其中最容易出错!【参考方案2】:
感谢 A2A。我也遇到过同样的问题。下面的代码会对你有所帮助。
unsigned int r,g,b; // Pixel data in the RGB
unsigned char x1,x2; // The container for resulting 2 bytes
x1 = (r & 0xF8) | (g >> 5); // Take 5 bits of Red component and 3 bits of G component
x2 = ((g & 0x1C) << 3) | (b >> 3); // Take remaining 3 Bits of G component and 5 bits of Blue component
您可以在 GIThub 中找到 python 程序。 https://github.com/ajay126z/RGB888ToRGB565-Converter
【讨论】:
以上是关于RGB888 到 RGB565 / 位移的主要内容,如果未能解决你的问题,请参考以下文章