Fortress Commander is a game about protecting your fortress from incoming waves of enemies. It descends from the RTS genre, and incorporates many classic RTS game mechanics, such as passive resource gathering, a battle system, and assigning actions and destinations to controllable entities (using the game engine's implementation of A* pathfinding). The game is implemented in its own custom Entity-Component System and pub-sub Event Manager. The graphics were entirely written in OpenGL.
- An Entity-Component-System framework that we use extensively in the game
- An event manager used for decoupling events from their handlers
- A tiling system complete with unit/structure creation and world editing
- A* pathfinding system
- An OpenGL-based 2D graphics interface
- Input Handling
- Atlassing Texture System
- A window manager wrapped around GLFW3
- Text Rendering from Freetype
- Perlin Noise-based Terrain Generation
Fortress Commander implements the following systems:
- Pathfinding
- Battle
- Particles
- EnemySpawning
- Resources
- Health
- UnitCommand
If you have the correct dependencies installed, simply run make
. The cmake build will be triggered, and the makefile will run the game binary for you.
Use the keyboard to move the camera You can interact with the map with the mouse. Left click and drag to make a selection area. Right click to give a command to selected units. Use the following keys to switch modes:
- B = Build (use number keys to select which type of structure)
- U = Unit
- X = Sell
- Q = Exit mode
You can use Escape to pause the game at any time.
- GLFW3
- FreeType
- clang-format
- gdb
- valgrind
- CMake
- GNU Make
- OpenGL
- GLFW3
- FreeType