Skip to content

JeanPhilippeKernel/RendererEngine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

e795414 · Mar 12, 2025
Nov 25, 2024
Aug 19, 2024
Nov 25, 2024
Jan 24, 2025
Jan 6, 2025
Mar 12, 2025
Jan 24, 2025
Mar 12, 2025
Jan 6, 2025
Jul 31, 2020
Jul 31, 2020
Nov 30, 2024
Mar 12, 2025
Mar 12, 2025
Nov 11, 2021
Nov 11, 2021
Aug 22, 2020
Jan 30, 2025
Jan 30, 2025
Nov 30, 2024
Sep 8, 2024

Repository files navigation

[Engine Build and Tests]

Discord Server

ZEngine

ZEngine is an open-source 3D rendering engine written in C++ and using Vulkan as graphic API. It can be used for activities such as:

  • Gaming
  • Scientific computation and visualization

Supported Platforms:

  • Windows
  • macOS (Under active revision as of today)
  • Linux (Debian or Ubuntu are recommended systems) (Under active revision as of today)

Setup

Before building, make sure your setup is correct :

Setup Window machine

Setup macOS machine

  • Install Xcode from the App Store.
  • Install Homebrew from a terminal:
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
  • Install CMake through Homebrew :
    brew update
    brew install cmake
  • Install NuGet through Homebrew :
    brew update
    brew install nuget
  • Install PowerShell Core through Homebrew:
    brew update
    brew install --cask powershell
  • Install DOTNET SDK 8

  • Install ClangFormat through Homebrew:

    brew update
    brew install clang-format@18

Building the engine & launcher

  1. Start Powershell Core and make sure that you can run CMake, You can type cmake --version to simply output the current CMake version installed.
  2. Change directories to the location where you've cloned the repository.
  3. Run the following command depending on the configuration:
    • Debug version : .\Scripts\BuildEngine.ps1 -Configurations Debug -RunBuilds $True
    • Release version : .\Scripts\BuildEngine.ps1 -Configurations Release -RunBuilds $True

Building the launcher only

To only build the Launcher only, you can specify -LauncherOnly which will skip building the engine :

  • Debug version : .\Scripts\BuildEngine.ps1 -Configurations Debug -RunBuilds $True -LauncherOnly
  • Release version : .\Scripts\BuildEngine.ps1 -Configurations Release -RunBuilds $True -LauncherOnly

Important Notes:

  • Setting -RunBuilds to $false will result to only generate the build directory.
  • Omitting -Configuration will result to generate and build for both Debug and Release versions.

Roadmap

See our roadmap here Roadmap

Dependencies

The project uses the following dependencies as submodules :

  • GLFW for window creation and user input management for Windows, Linux, and MacOS,
  • GLM for functions and mathematical calculations,
  • STB for loading and manipulating image files for textures.
  • ImGUI for GUI components and interaction.
  • SPDLOG for logging
  • EnTT for entity component system
  • Assimp for managing and loading asset 2D -3D models
  • yaml-cpp for parsing and emitting YAML files