sdlGetRgb function

void sdlGetRgb(
  1. int pixel,
  2. Pointer<SdlPixelFormatDetails> format,
  3. Pointer<SdlPalette> palette,
  4. Pointer<Uint8> r,
  5. Pointer<Uint8> g,
  6. Pointer<Uint8> b,
)

Get RGB values from a pixel in the specified format.

This function uses the entire 8-bit 0..255 range when converting color components from pixel formats with less than 8-bits per RGB component (e.g., a completely white pixel in 16-bit RGB565 format would return 0xff, 0xff, 0xff not 0xf8, 0xfc, 0xf8).

\param pixel a pixel value. \param format a pointer to SDL_PixelFormatDetails describing the pixel format. \param palette an optional palette for indexed formats, may be NULL. \param r a pointer filled in with the red component, may be NULL. \param g a pointer filled in with the green component, may be NULL. \param b a pointer filled in with the blue component, may be NULL.

\threadsafety It is safe to call this function from any thread, as long as the palette is not modified.

\since This function is available since SDL 3.1.3.

\sa SDL_GetPixelFormatDetails \sa SDL_GetRGBA \sa SDL_MapRGB \sa SDL_MapRGBA

extern SDL_DECLSPEC void SDLCALL SDL_GetRGB(Uint32 pixel, const SDL_PixelFormatDetails *format, const SDL_Palette *palette, Uint8 *r, Uint8 *g, Uint8 *b)

Implementation

void sdlGetRgb(
    int pixel,
    Pointer<SdlPixelFormatDetails> format,
    Pointer<SdlPalette> palette,
    Pointer<Uint8> r,
    Pointer<Uint8> g,
    Pointer<Uint8> b) {
  final sdlGetRgbLookupFunction = libSdl3.lookupFunction<
      Void Function(
          Uint32 pixel,
          Pointer<SdlPixelFormatDetails> format,
          Pointer<SdlPalette> palette,
          Pointer<Uint8> r,
          Pointer<Uint8> g,
          Pointer<Uint8> b),
      void Function(
          int pixel,
          Pointer<SdlPixelFormatDetails> format,
          Pointer<SdlPalette> palette,
          Pointer<Uint8> r,
          Pointer<Uint8> g,
          Pointer<Uint8> b)>('SDL_GetRGB');
  return sdlGetRgbLookupFunction(pixel, format, palette, r, g, b);
}