11

ビットシフトを使用して、3 つの文字を短い文字に結合したいと考えています。これは、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 );
}

最後に、私の望ましい結果を見ることができます。助けてくれてありがとう!

4

2 に答える 2

16
rgb = ((r & 0b11111000) << 8) | ((g & 0b11111100) << 3) | (b >> 3);

r11 ビット左にシフトし、5 ビット左にシフトし、これらを3 ビット右にシフトgしてビットごとに OR します。b(注: これは、不要なビットを削除するために、必要に応じて値が既に正しくマスクされていることを前提としています。)

于 2012-07-13T13:23:17.450 に答える