RGB888 para RGB565 / deslocamento de bit
Eu quero combinar três caracteres em um curto usando o deslocamento de bits. Isso é para implementar a paleta de cores RGB565 (onde há 5 bits para vermelho, 6 para verde, 5 para azul).
Aqui está o meu programa de exemplo, eu só estou perdendo um passo no meio eu acho que eu preciso fazer algumas anding.
#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 );
}
Você pode ver o resultado desejado no final. Obrigado pela ajuda!