Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thangisme/spectra
https://github.com/thangisme/spectra
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/thangisme/spectra
- Owner: thangisme
- Created: 2024-02-25T14:33:38.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-04-17T04:09:03.000Z (9 months ago)
- Last Synced: 2024-05-17T07:48:12.488Z (8 months ago)
- Language: C++
- Size: 44.4 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![Build](https://github.com/thangisme/Spectra/actions/workflows/cmake-sdl2-build.yml/badge.svg)](https://github.com/thangisme/Spectra/actions/workflows/cmake-sdl2-build.yml)
Spectra
Simple shooting game built with SDL2
## Gameplay demo
You can view the demo video on [Youtube](https://www.youtube.com/watch?v=O_9oMhhOk9w)### Screenshot
| ![splashscreen](assets/screenshots/splash_screen.png) | ![guidescreen](assets/screenshots/guide_screen.png) | ![winscreen](assets/screenshots/win_screen.png) |
|:-----------------------------------------------------:|:---------------------------------------------------:|:-----------------------------------------------:|
| Start menu | New player screen | Win screen || ![map1](assets/screenshots/map1.png) | ![map1](assets/screenshots/map2.png) |
|:------------------------------------:|:------------------------------------:|
| Map 1 | Map 2 |## Technical design overview
The game's functionalities are organized into separate classes, utilizing Object-Oriented Programming (OOP) principles to make the codebase more modular and maintainable.The `Game` class acts like the brain of the program, control various parts of the game.
* `TextureManager` class is responsible for loading and rendering textures.
* `SoundManager` class is responsible for loading and playing sound effects.
* `InputManager` class is responsible for handling user input.
* The `GameObject` class is the base class for all game objects, which includes the player, enemies, bullets, ... Each of these classes inherits from the `GameObject` class and implements their own functionalities.The core game loop is implemented in the `Game` class, which handle events -> update game objects -> render game objects -> repeat.
Update loop basically calls the `GameStateManager` class to handle the current state.
Most of state classes are also inherit from the `MenuState` class which base class is `GameState`.
These classes call `StateParser` class to parse the data from an external XML file which then render various game objects on the screen. The **[tinyxml2](https://github.com/leethomason/tinyxml2)** library is used to parse the XML file.The only exception is the `PlayState` class which call the `LevelParser` class instead. This class also parses the data from an external map file, but designed specifically for handling the [Tiled](https://www.mapeditor.org/) map file format. The [base64](https://github.com/ReneNyffenegger/cpp-base64) and [zlib](https://www.zlib.net/) libraries are used to decode the map data.
Due to the space between frame in some object sprite sheets, the collision detection is not pixel-perfect. Instead, the `CollisionManager` class check for outer edges of the object minus a fixed offset to determine the collision.
## Download
Windows users can download the latest release [here](https://github.com/thangisme/Spectra/releases).## Build and Run
### PrerequisitesFirst, you need to make sure to have the following dependencies installed on your machine:
* [CMake](https://cmake.org/download/)
* [SDL2](https://www.libsdl.org/download-2.0.php)
* [SDL2_image](https://www.libsdl.org/projects/SDL_image/)
* [SDL2_mixer](https://www.libsdl.org/projects/SDL_mixer/)If you're running on Ubuntu, you can install them by running the following command:
```sh
sudo apt-get install -y libsdl2-dev libsdl2-2.0-0 libsdl2-image-dev libjpeg-dev libwebp-dev libtiff5-dev libsdl2-image-dev libsdl2-image-2.0-0 libmikmod-dev libfishsound1-dev libsmpeg-dev liboggz2-dev libflac-dev libfluidsynth-dev libsdl2-mixer-dev libsdl2-mixer-2.0-0 zlib1g-dev
```### Build
To build the project, navigate to the root directory and run the following command:
```sh
cmake -S . -B build
cmake --build build
```### Run
If the build process succeed, you can find the executable file in the `build` directory. To run the game, simply run the following command:
```sh
./build/Spectra
```