Using logical bitshift for RGB values

后端 未结 1 878
慢半拍i
慢半拍i 2021-01-06 08:36

I\'m a bit naive when it comes to bitwise logic and I have what is probably a simple question... basically if I have this (is ActionScript but can apply in many languages):<

相关标签:
1条回答
  • 2021-01-06 09:13

    In RGB you have 8 bits for Red, 8 bits for Green and 8 bits for Blue. You are storing the 3 bytes in an int, which has 4 bytes in this way:

    • Bits from 0-7(least significant) for Blue.
    • Bits from 8-15(least significant) for Green.
    • Bits from 16-23(least significant) for Red.

    To extract them to separate values you need to right shift the correct number of bits in order to put the byte corresponding to the color you want to extract in the least significant byte of the int, and then put the rest of the int in 0 so as to let that byte value only. The last part is done by using the AND operation with mask 0xFF. The AND leaves the only byte of the int where it is applied with the same value, leaving the rest bytes in 0.

    This is what happens:

    var color:uint = myObject.color;
    

    You have the color variable like this: 0x00RRGGBB

    var red:uint = color >>> 16;
    

    Right-shifting 16 bits color results in: 0x000000RR, resulting in the red value.

    But for:

    var green:uint = color >>> 8 & 0xFF;
    

    After right-shifting color 8 bits it leaves this result 0x0000RRGG, but here we only need the GG bits left so we apply the AND operation with the mask 0xFF or to be more clear 0x000000FF, as you show know AND leaves the old bits values where the mask is 1 and zeros there the mask is 0, so the result of doing 0x0000RRGG & 0x000000FF = 0x000000GG which is the value for green. The same is applied to extract the blue value.

    0 讨论(0)
提交回复
热议问题