(This is the documentation for SDL3, which is under heavy development and the API is changing! SDL2 is the current stable version!)

SDL_LockSurface

Set up a surface for directly accessing the pixels.

Header File

Defined in <SDL3/SDL_surface.h>

Syntax

int SDL_LockSurface(SDL_Surface *surface);

Function Parameters

surface the SDL_Surface structure to be locked

Return Value

Returns 0 on success or a negative error code on failure; call SDL_GetError() for more information.

Remarks

Between calls to SDL_LockSurface() / SDL_UnlockSurface(), you can write to and read from surface->pixels, using the pixel format stored in surface->format. Once you are done accessing the surface, you should use SDL_UnlockSurface() to release it.

Not all surfaces require locking. If SDL_MUSTLOCK(surface) evaluates to 0, then you can read and write to the surface at any time, and the pixel format of the surface will not change.

Version

This function is available since SDL 3.0.0.

Code Examples

void modify_surface(SDL_Surface *surface) {

  /* Make the pixels pointer valid in the surface */

  SDL_LockSurface(surface);

  /* Surface is locked */
  /* Direct pixel access on surface here */

  SDL_UnlockSurface(surface);

  /* Surface is now unlocked */
}

See Also


CategoryAPI, CategoryAPIFunction, CategorySurface