Retrieves a single pixel from a surface.
Defined in <SDL3/SDL_surface.h>
bool SDL_ReadSurfacePixel(SDL_Surface *surface, int x, int y, Uint8 *r, Uint8 *g, Uint8 *b, Uint8 *a);| SDL_Surface * | surface | the surface to read. | 
| int | x | the horizontal coordinate, 0 <= x < width. | 
| int | y | the vertical coordinate, 0 <= y < height. | 
| Uint8 * | r | a pointer filled in with the red channel, 0-255, or NULL to ignore this channel. | 
| Uint8 * | g | a pointer filled in with the green channel, 0-255, or NULL to ignore this channel. | 
| Uint8 * | b | a pointer filled in with the blue channel, 0-255, or NULL to ignore this channel. | 
| Uint8 * | a | a pointer filled in with the alpha channel, 0-255, or NULL to ignore this channel. | 
(bool) Returns true on success or false on failure; call SDL_GetError() for more information.
This function prioritizes correctness over speed: it is suitable for unit tests, but is not intended for use in a game engine.
Like SDL_GetRGBA, this uses the entire 0..255 range when converting color components from pixel formats with less than 8 bits per RGB component.
This function can be called on different threads with different surfaces.
This function is available since SDL 3.2.0.