Hello SDL3

Last Updated: Mar 30th, 2026
So you learned the basics of C++, but you're sick of making little text based programs. In order to use things like graphics, sound, keyboards, game controllers, etc you need an API (Application Programmer's Interface) that takes all those hardware features and turns it into something C++ can interact with.That's what SDL does. It takes the Windows/Linux/Mac/Android/iOS/etc tools and wraps them in a way that you can code something in SDL and compile it to what ever platform it supports. In order to use it, you need to install it.
These set up tutorials are a supplement to assist you in setting up SDL. Certain companies (that shall remain nameless) keep changing their user
interfaces for their IDEs with every release, so the set up procedure may have changed since the tutorial was made. In case the IDE's interface has
changed since the tutorial was last updated, you can check out the
documentation on the SDL github between now and when the tutorial is updated.
SDL as a dynamically linked library. A dynamically linked library has 3 parts:
After your compiler compiles all your source files it has to link them together. In order for the program to link properly, it needs to know the addresses of all your functions including the ones for SDL. For a dynamically linked library, these addresses are in the library file. The library file has the Import Address Table so your program can import the functions at runtime. Like with header files you need to configure your compiler to search in an additional directory where the SDL library files are located. You also have to tell the linker to link against the library file in the linker. If the linker complains that it can't find
After your program is compiled and linked, you need to be able to link against the library when you run it. In order to run a dynamically linked application, you need to be able to import the library binaries at runtime. Your operating system needs to be able to find the library binary when you run your program. You can either put the library binaries in the same directory as your executable, a directory that your operating system keeps library binary files, or tell the operating system to look in a custom directory that has the binary files via the
Once you set up SDL, we'll cover your first SDL3 application.
SDL as a dynamically linked library. A dynamically linked library has 3 parts:
- The header files (Library.h)
- The library files (Library.lib for windows or libLibrary.a for *nix)
- The binary files (Library.dll for windows or Library.so for *nix)
SDL_Init() and the other SDL functions and
structures are. You need to configure your compiler to search in an additional directory where the SDL header files are located. If the compiler
complains that it can't find SDL.h, it means the header files aren't in a place that the compiler looks for header files.After your compiler compiles all your source files it has to link them together. In order for the program to link properly, it needs to know the addresses of all your functions including the ones for SDL. For a dynamically linked library, these addresses are in the library file. The library file has the Import Address Table so your program can import the functions at runtime. Like with header files you need to configure your compiler to search in an additional directory where the SDL library files are located. You also have to tell the linker to link against the library file in the linker. If the linker complains that it can't find
-lSDL2 or SDL2.lib, it means the library files aren't in a place
that the linker looks for library files. If the linker complains about an undefined reference, it probably means it was never told to link the
library.After your program is compiled and linked, you need to be able to link against the library when you run it. In order to run a dynamically linked application, you need to be able to import the library binaries at runtime. Your operating system needs to be able to find the library binary when you run your program. You can either put the library binaries in the same directory as your executable, a directory that your operating system keeps library binary files, or tell the operating system to look in a custom directory that has the binary files via the
PATH
variable.Once you set up SDL, we'll cover your first SDL3 application.
| Select Your Operating System | |
|---|---|
![]() |
Setting up SDL on Windows |
