SDL Wiki
[ front page | index | search | recent changes | git repo | offline html ]

SDL_ConvertSurface

Copy an existing surface to a new surface of the specified format.

Header File

Defined in <SDL3/SDL_surface.h>

Syntax

SDL_Surface * SDL_ConvertSurface(SDL_Surface *surface, SDL_PixelFormat format);

Function Parameters

SDL_Surface * surface the existing SDL_Surface structure to convert.
SDL_PixelFormat format the new pixel format.

Return Value

(SDL_Surface *) Returns the new SDL_Surface structure that is created or NULL on failure; call SDL_GetError() for more information.

Remarks

This function is used to optimize images for faster repeat blitting. This is accomplished by converting the original and storing the result as a new surface. The new, optimized surface can then be used as the source for future blits, making them faster.

If you are converting to an indexed surface and want to map colors to a palette, you can use SDL_ConvertSurfaceAndColorspace() instead.

If the original surface has alternate images, the new surface will have a reference to them as well.

Thread Safety

This function can be called on different threads with different surfaces.

Version

This function is available since SDL 3.2.0.

Code Examples


SDL_Surface *input;
SDL_Surface *output = SDL_ConvertSurface(input, SDL_PIXELFORMAT_RGBA32);

See Also


CategoryAPI, CategoryAPIFunction, CategorySurface


[ edit | delete | history | feedback | raw ]

All wiki content is licensed under Creative Commons Attribution 4.0 International (CC BY 4.0).
Wiki powered by ghwikipp.