Skip to the content.

Cairo pixel formats

All Cairo formats are packed formats (but see the special case). The format definitions follow the scheme:

CAIRO_FORMAT_{components}{total-size}(_{sizes})

The components part specifies the order of the components in a native type, with the leftmost component stored in the most significant bits, and the rightmost component in the least significant bits. The total size of the bits of the components is specified in total-size.

If sizes is not present, then the size in bits of each component is equal to the total-size divided by the number of components.

If sizes is present, then the size in bits of each component is specified by the corresponding digit in sizes.

Formats with total sizes not matching the size of a native type (8, 16 or 32 bits) are stored in the native type of the least size that can fit them (e.g., a format with total-size of 24 is stored in a 32-bit type). Any unused bits are always the most significant bits, followed by the components in the order specified in components.

The memory layout of Cairo formats depends on system endianness.

Example: CAIRO_FORMAT_ARGB32

The pixel is represented by a 32-bit value, with A in bits 24-31, R in bits 16-23, G in bits 8-15 and B in bits 0-7:

M                                                              L
A₇A₆A₅A₄A₃A₂A₁A₀R₇R₆R₅R₄R₃R₂R₁R₀G₇G₆G₅G₄G₃G₂G₁G₀B₇B₆B₅B₄B₃B₂B₁B₀

On little-endian systems the pixel is stored in memory as the bytes B, G, R, A (B at the lowest address, A at the highest).

On big-endian systems the pixel is stored in memory as the bytes A, R, G, B (A at the lowest address, B at the highest).

Example: CAIRO_FORMAT_RGB24

The pixel is represented by a 32-bit value, with R in bits 16-23, G in bits 8-15, B in bits 0-7, with the bits 24-31 being unused:

M                                                              L
X₇X₆X₅X₄X₃X₂X₁X₀R₇R₆R₅R₄R₃R₂R₁R₀G₇G₆G₅G₄G₃G₂G₁G₀B₇B₆B₅B₄B₃B₂B₁B₀

On little-endian systems the pixel is stored in memory as the bytes B, G, R, X (B at the lowest address, X at the highest).

On big-endian systems the pixel is stored in memory as the bytes X, R, G, B, (X at the lowest address, B at the highest).

Example: CAIRO_FORMAT_RGB16_565

The pixel is represented by a 16-bit value, with R in bits 11-15, G in bits 5-10 and B in bits 0-4:

M                              L
R₄R₃R₂R₁R₀G₅G₄G₃G₂G₁G₀B₄B₃B₂B₁B₀

On little-endian systems the pixel is stored in memory as:

0                1
M              L M              L
G₂G₁G₀B₄B₃B₂B₁B₀ R₄R₃R₂R₁R₀G₅G₄G₃

On big-endian systems the pixel is stored in memory as:

0                1
M              L M              L
R₄R₃R₂R₁R₀G₅G₄G₃ G₂G₁G₀B₄B₃B₂B₁B₀

Special case: 1bpp pixel format

Cairo supports the CAIRO_FORMAT_A1 pixel format that describes pixels with a size of a single bit. The way multiple pixels of this format are stored in a byte depends on system endianness.

On little-endian systems the bit of a pixel in a pixel series is stored in the least significant available bit of the current byte. When the byte fills up, storage is moved to the next byte.

On big-endian systems the bit of a pixel in a pixel series is stored in the most significant available bit of the current byte. When the byte fills up, storage is moved to the next byte.

To better illustrate the storage scheme, the examples below show how a series of pixels is stored in memory.

Example: CAIRO_FORMAT_A1

Each pixel is represented as a 1-bit value:

A₀

On little-endian systems the 16 pixels ABC…NOP are stored as:

0                1
M              L M              L
H₀G₀F₀E₀D₀C₀B₀A₀ P₀O₀N₀M₀L₀K₀J₀I₀

On big-endian systems the 16 pixels ABC…NOP are stored as:

0                1
M              L M              L
A₀B₀C₀D₀E₀F₀G₀H₀ I₀J₀K₀L₀M₀N₀O₀P₀