Simple DirectMedia Layer is a cross-platform development library designed to provide low level access to audio, keyboard, mouse, joystick, and graphics hardware via OpenGL and Direct3D. It is used by video playback software, emulators, and popular games including Valve's award winning catalog and many Humble Bundle games.
SDL officially supports Windows, Mac OS X, Linux, iOS, and Android. Support for other platforms may be found in the source code.
- For the latest information on what is supported see the page about Installation.
- For the latest list of languages see http://www.libsdl.org/languages.php
Read ahead for an overview of what SDL is capable of. If you're simply interested in the changes from 1.2 to 2.0, check out the Migration Guide.
Video
- 3D graphics:
- SDL can be used in combination with the OpenGL API or Direct3D API for 3D graphics
- Accelerated 2D render API:
- Supports easy rotation, scaling and alpha blending, all accelerated using modern 3D APIs
- Acceleration is supported using OpenGL and Direct3D, and there is a software fallback
- Create and manage multiple windows
- Events and API functions provided for:
- Application and window state changes
- Mouse input
- Keyboard input
- Joystick and game controller input
- Multitouch gestures
- Each event can be enabled or disabled with SDL_EventState()
- Events are passed through a user-specified filter function before being posted to the internal event queue
- Thread-safe event queue
- Force feedback is supported under Windows, Mac OS X and Linux
- Set audio playback of 8-bit and 16-bit audio, mono stereo or 5.1 surround sound, with optional conversion if the format is not supported by the hardware
- Audio runs independently in a separate thread, filled via a user callback mechanism
- Designed for custom software audio mixers, but SDL_mixer provides a complete audio/music output library
- General purpose abstraction for opening, reading and writing data
- Built-in support for files and memory
- Load shared objects (DLL on Windows, .dylib on Mac OS X, .so on Linux)
- Lookup functions in shared objects
- Simple thread creation API
- Simple thread local storage API
- Mutexes, semaphores and condition variables
- Atomic operations for lockless programming
- Get the number of milliseconds elapsed
- Wait a specified number of milliseconds
- Create timers that run alongside your code in a separate thread
- Use high resolution counter for profiling
- Query the number of CPUs
- Detect CPU features and supported instruction sets
- Detect the endianness of the current system
- Routines for fast swapping of data values
- Read and write data of a specified endianness
- Querying power management status
Windows
- Uses Win32 APIs for display, taking advantage of Direct3D for hardware acceleration
- Uses DirectSound and XAudio2 for sound
- Uses Cocoa for video display, taking advantage of OpenGL for hardware acceleration
- Uses Core Audio for sound
- Uses X11 for video display, taking advantage of OpenGL for hardware acceleration
- Uses the ALSA, OSS and PulseAudio APIs for sound
- Uses UIKit for video display, taking advantage of OpenGL ES 2.0 for hardware acceleration
- Uses Core Audio for sound
- Uses JNI interfaces for video display, taking advantage of OpenGL ES 1.1 and 2.0 for hardware acceleration
- Uses JNI audio callbacks for sound
- See also Android
You can get the source code and build and install it.
If you used SDL 1.2 previously and you want to use SDL 2.0, please note there are some API changes and some of your code will need to be adapted.
The migration guide lists the feature differences and how to adapt old code to the new SDL 2.0: