RGB888 bis RGB565 / Bitverschiebung
Ich möchte drei Zeichen durch Bitverschiebung zu einer kurzen kombinieren. Dies dient zur Implementierung der RGB565-Farbpalette (5 Bit für Rot, 6 für Grün, 5 für Blau).
Hier ist mein Beispielprogramm, ich vermisse nur einen Schritt in der Mitte, in dem ich denke, ich muss etwas anding tun.
#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 );
}
Sie können mein gewünschtes Ergebnis am Ende sehen. Danke für die Hilfe!