A template for an SDL2 game made using C++. Use this as a sort of blank slate with all the basic classes, functions and necessary variables you need to create your own games. To run your game built with this template, you can either simply run the python file run.py
, which will compile and run your game if possible or run the previously compiled version of the game in case of compilation errors, or you can directly run g++ -o <insert game name here>.exe main.cpp -lmingw32 -lSDL2main -lSDL2 -lSDL2_Image -lSDL2_mixer -lSDL2_ttf -I src -std=c++20
in your terminal.
- Image class (handles texture rendering for you)
- Sound class (handles audio playing for you, can play multiple sounds together using as many channels as you like if you modify the number in the Mix_AllocateChannels function on line 199 of core_funcs.hpp)
- Text class (handles text rendering for you, renders text in white by default but can render in any color if you modify fColor externally)
- Spritesheet class (splits a SDL_Surface spritesheet into various SDL_Texture s and stores them in an array, which you can access with Spritesheet::get)
- Surf_Spritesheet class (splits a SDL_Surface spritesheet into various SDL_Surface s and stores them in an array, which you can access with Surf_Spritesheet::get)
- Sprite class (stores an image along with a chain of rects that represent its outline, can be used for pixel perfect collision)
- AnimatedSprite class (splits a SDL_Surface spritesheet into various SDL_Texture s and assigns each one to a Sprite object, then updates them one by one to play the animation with rects stored for pixel perfect collision.)
- Button class (a clickable button capable of taking a function as an argument and executing it when clicked. Also comes with a sound effect)
- Slider class (a draggable ui slider that can be operated with both keyboard and mouse)
- fn<> (allows you to store a function as a variable. meant to be used to pass a function as an argument to a button)
- SpriteStack class (allows you to render sprite-stacks).
Important information about the classes:
-
The sprite class requires an SDL_Surface at its original size to be passed in, and the scale you want the image to be can be put in as an argument. By default the Sprite::update method will also render the outline rects. This is a debugging feature and you can remove the for loop at the end of Sprite::update if you just want the image to render.
-
Also, the AnimatedSprite class takes an optional framechange_ argument. This represents the number of frames the program waits before moving on from one frame to the next. By default, this value is set at 8.
-
The two spritesheet classes, the SpriteStack class and also the AnimatedSprite class take in a size argument. This represents the number of rows and columns of frames in a spritesheet. So for example for this image: which is a spritesheet for a button, the size would be [2, 1] since there are 2 columns and 1 row.
-
The AnimatedSprite class as of currently can only use spritesheets with a single row. This may be improved in the future depending on my requirements for my own games.
-
To use fn<>, for example in the following case:
int test(const char* c, bool to_print){
if (to_print) cout << c << endl;
return 1;
}
You have to pass in the return type, then the various types of the arguments like this: auto test_func = fn<int, const char*, bool>(test);
- To use the SpriteStack class, you have to first create a SpriteStack object, then initialize it by using the
SpriteStack::init
passing in the sprite sheet containing your sprite-stack layers, the size (number of rows and columns) of your spritesheet (as explained in the above note about the size argument) and the spread value of your sprite-stack. Simply load the spritesheet as a surface and then pass it in as an argument; don't pass it in as aSurf_Spritesheet
orSpritesheet
object. In order to render the spritestack, use theSpriteStack::render
method, which takes a position argument in the form of an SDL_Point, an angle argument, and a scale argument allowing you to increase or decrease the size at which your SpriteStack will be rendered. WARNING: This class only works if your sprite sheet containing all the sprite-stack layers has all its sprites vertically one on top of the other. Horizontal spritesheet alignment won't work. Also, another thing you should note is that the spritestack class uses caching for optimization which can take quite a lot of RAM if you use a model with too many layers. The max layers you can render depend on your PC but are probably in the thousands or tens of thousands, so there is no need to worry about RAM usage in most cases.
- scale_surface (scales a surface up or down)
- rotate_surface (rotates a surface by a particular angle in degrees)
- getsize (returns width and height of a texture as an SDL_Point. Width can be accessed as the x value and height as the y value of the point.)
- get_at (returns the RGB color value of a particular pixel in a SDL_Surface)
- scale_image (meant to be used on an Image object to scale it up or down)
- rotate_image (meant to be used on an Image object to rotate it by a particular angle in degrees)
- SDL_RenderOnTexture (renders a texture on another texture)
- There are five Uint32 color variable meant to be used for setting colorkeys. These are black, white, red, green and blue.
- There is a Uint32 * variable button_state, which is updated every frame using SDL_GetMouseState and stores the current state of the mouse buttons. The SDL_Point mousepos variable is also updated along with it.
- There is a Uint8 * variable keyboard_state which is updated every frame using SDL_GetKeyboardState and stores the current state of the keyboard
- There is a FRAMES_PER_SECOND value with which you can set the fps at which the game will run.
Finally, the excellent random library by effolkronium (https://github.com/effolkronium/) is also included and the namespace Random is used in core_funcs.hpp.