Vadon is a cross-platform general-purpose game engine implemented using C++ and the CMake build system. It offers a development environment using the latest features of C++ and modern programming paradigms and architectures.
- Build system via CMake
- Dependency management via CPM
- Object pools and manager systems with convenient access pattern
- Graphics API abstraction (currently only supports DirectX 11)
- Render frame graphs
- Task graph and job threads
- Custom Entity component system (ECS, implementation details inspired in part by EnTT)
- Custom reflection and RTTI system (inspired by Godot)
- Scene system (inspired by Godot)
- Application API (wrapper for platform, windows, etc.)
- Editor API (provides basic editing functionality, can be customized for projects)
- Developer GUI for dev tools and debugging (currently uses Dear ImGui)
- 2D rendering via Canvas API
- File management
- Serialization using JSON
- Demo application to showcase features
- Modular structure, allowing client code to only use the engine features they require
- Basic 3D rendering pipeline
- Options for both 2D and 3D rendering to allow creating custom pipelines
- Basic engine update loop
- Refined API for custom update logic, task/job based update, etc.
- Binary serialization
- Physics and audio support
- CMake version 3.21 or higher
Default configurations are provided in "CMakePresets.json" (compatible GUI apps will display these as config options).
Create "CMakeUserPresets.json" to add custom configurations (e.g "no GUI").
Navigate to source folder, use cmake --preset=PRESET-NAME
to generate the project with the desired configuration.
- Currently only works in Visual Studio 2022
Open the project folder using VS. Toolbar will display target system, configuration, and build presets (this includes any custom presets in CMakeUserPresets.json).
Select desired configuration, then build and run.
By default, the engine offers configurations for dynamic linking, which can be useful during development. For released builds, static linking is recommended.
Core project, contains all the context-agnostic features
Base library, provides common features for all other modules.
- Engine core interface
- Engine subsystem interface
- ECS API
- Scene API
- Task system
- Utilities
Mid-level renderer API, provides features that composite low-level API features.
- Render frame graph
- Utilities
Low-level renderer API and abstraction layer.
- Null graphics API (for debugging or when run without graphics)
- DirectX graphics API
Implementations for engine interfaces, creates core object for client code
For projects that want to delegate platform management (windows, inputs, etc.), this library provides an abstraction layer, along with some extra features.
Currently only supports a single window being used as the "main window".
Also provides immediate mode developer GUI.
Derived from Application, allows clients to create and edit scenes via ECS. Custom Component types can be registered and will be available in the editor as well.
Optional projects to showcase how Vadon can be used to create a game application, as well as the relevant dev tools.
Shared code, including the custom Component types for the ECS and the logic of the game model.
This project derives from the Editor library and combines it with the Demo game model in Common. It also runs custom logic (e.g rendering) while editing based on the scene contents.
This project derives from the Application library and combines with the Demo game model in Common to create a game instance. It loads content created in the editor and runs the game simulation.
The included demo projects illustrate how Vadon can be used to create a game. Set up an executable target, then import the engine as a library.
The CMake script contains options that can be set for when the engine is imported as a third-party package into a project.