sdlMapRgb function

int sdlMapRgb(
  1. Pointer<SdlPixelFormatDetails> format,
  2. Pointer<SdlPalette> palette,
  3. int r,
  4. int g,
  5. int b,
)

Map an RGB triple to an opaque pixel value for a given pixel format.

This function maps the RGB color value to the specified pixel format and returns the pixel value best approximating the given RGB color value for the given pixel format.

If the format has a palette (8-bit) the index of the closest matching color in the palette will be returned.

If the specified pixel format has an alpha component it will be returned as all 1 bits (fully opaque).

If the pixel format bpp (color depth) is less than 32-bpp then the unused upper bits of the return value can safely be ignored (e.g., with a 16-bpp format the return value can be assigned to a Uint16, and similarly a Uint8 for an 8-bpp format).

\param format a pointer to SDL_PixelFormatDetails describing the pixel format. \param palette an optional palette for indexed formats, may be NULL. \param r the red component of the pixel in the range 0-255. \param g the green component of the pixel in the range 0-255. \param b the blue component of the pixel in the range 0-255. \returns a pixel value.

\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_GetRGB \sa SDL_MapRGBA \sa SDL_MapSurfaceRGB

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

Implementation

int sdlMapRgb(Pointer<SdlPixelFormatDetails> format,
    Pointer<SdlPalette> palette, int r, int g, int b) {
  final sdlMapRgbLookupFunction = libSdl3.lookupFunction<
      Uint32 Function(Pointer<SdlPixelFormatDetails> format,
          Pointer<SdlPalette> palette, Uint8 r, Uint8 g, Uint8 b),
      int Function(Pointer<SdlPixelFormatDetails> format,
          Pointer<SdlPalette> palette, int r, int g, int b)>('SDL_MapRGB');
  return sdlMapRgbLookupFunction(format, palette, r, g, b);
}