(This is the legacy documentation for stable SDL2, the current stable version; SDL3 is the current development version.)

SDL_CreateCursor

Create a cursor using the specified bitmap data and mask (in MSB format).

Header File

Defined in SDL_mouse.h

Syntax

SDL_Cursor* SDL_CreateCursor(const Uint8 * data,
                             const Uint8 * mask,
                             int w, int h, int hot_x,
                             int hot_y);

Function Parameters

data the color value for each pixel of the cursor
mask the mask value for each pixel of the cursor
w the width of the cursor
h the height of the cursor
hot_x the X-axis location of the upper left corner of the cursor relative to the actual mouse position
hot_y the Y-axis location of the upper left corner of the cursor relative to the actual mouse position

Return Value

Returns a new cursor with the specified parameters on success or NULL on failure; call SDL_GetError() for more information.

Remarks

mask has to be in MSB (Most Significant Bit) format.

The cursor width (w) must be a multiple of 8 bits.

The cursor is created in black and white according to the following:

Cursors created with this function must be freed with SDL_FreeCursor().

If you want to have a color cursor, or create your cursor from an SDL_Surface, you should use SDL_CreateColorCursor(). Alternately, you can hide the cursor and draw your own as part of your game's rendering, but it will be bound to the framerate.

Also, since SDL 2.0.0, SDL_CreateSystemCursor() is available, which provides twelve readily available system cursors to pick from.

Version

This function is available since SDL 2.0.0.

See Also


CategoryAPI, CategoryAPIFunction, CategoryMouse