Skip to content

PanosK92/SpartanEngine

Repository files navigation

Spartan Engine is one of the most advanced one-man game engines out there, pushing the limits of real-time approaches. What started as a portfolio project has evolved into a cutting-edge project for developers to explore, learn, and contribute. This isn't an engine for the average user, it's designed for advanced research and experimentation, ideal for industry veterans looking to experiment, not to build a game (yet). With a thriving Discord community of over 440 members, including industry veterans, and contribution perks that you won't believe when you see, it's one of the most unique projects you'll come across.

  • For occasional updates regarding the project's development, you can follow me on X.

  • For a community like no other, join our group of 400+ members on discord.

  • For issues and anything directly related to the project, feel free to open an issue.

  • Please adhere to the MIT license. You're free to copy the code, provided you include the original license.

Status

build_status Discord

Media

Video: Livestream of FSR 2 integration Video: The engine and the community
Image1 Image2

Worlds

Upon launching the engine, you'll be greeted with a selection of default worlds to load. Each world is physics-enabled, allowing you to walk around, pick objects using your mouse, and even drive a car. These worlds are designed to offer a diverse and enjoyable experience

Sponza Forest

The Sponza building, found in Dubrovnik, is showcased here with a true-to-life scale.

A height map-generated forest featuring water bodies amidst tens of thousands of trees and plants, all set in a walkable terrain.
Car Doom

A drivable car implemented with a highly realistic tire friction formula, simulation of gearbox, anti-roll bar, and more

This is a simple scene with the soundtrack from E1M1
Bistro Minecraft

Amazon Lumberyard Bistro

A good old minecraft world

Features

Rendering

  • Cutting edge Vulkan renderer.
  • 128-byte push constant buffer for lightning fast CPU to GPU data transfer.
  • On the fly single dispatch GPU-based mip generation for render targets (FidelityFX SPD).
  • On the fly compression and mip generation for material textures (FidelityFX Compressonator).
  • Fully bindless design (materials, lights, even the samplers).
  • Fast dual paraboloid point lights.
  • Vulkan (main) and DirectX 12 (wip) backends with universal HLSL shaders.
  • Unified deferred rendering with transparency (BSDF with same render path).
  • Atmospheric scattering, real-time filtering and image-based lighting.
  • Real-time global illumination (FidelityFX Brixelizer GI).
  • Screen space shadows (Bend Studio's Days Gone).
  • Screen space ambient occlusion.
  • Screen space reflections (FidelityFX SSSR).
  • Variable rate shading.
  • Dynamic resolution scaling.
  • Upscaling (FidelityFX FSR 3.1).
  • Temporal anti-aliasing.
  • Breadcrumbs for tracing GPU crashes on AMD (FidelityFX Breadcrumbs).
  • Advanced shadow features with penumbra and colored translucency.
  • Physical light units (intensity from lumens and color from kelvin).
  • Frustum & occlusion culling (software and hardware hybrid).
  • Physically based camera.
  • Volumetric fog.
  • HDR10 output.
  • Post-process effects like fxaa, bloom, motion-blur, depth of field, chromatic aberration etc.

General

  • One-click project generation for easy setup.
  • Universal input support, keyboard & mouse, controllers (tested a PS5 controller) and steering wheels.
  • Comprehensive physics features.
  • CPU & GPU profiling.
  • XML support for data handling.
  • Thread pool that can consume any workload.
  • Entity-component, event systems and most things you'll expect to find in a modern engine.
  • Wide file format support: 10+ for fonts, 20+ for audio, 30+ for images, and 40+ for models.

Documentation

The wiki can answer most of your questions, here are some of it's contents:

Tutorials

While the engine is designed primarily for experienced game developers to experiment, there are resources available for those who prefer a more guided approach.

To get started, take a look at game.cpp. This file contains all the logic for loading and setting up the default worlds within the engine, and it's a great place to understand the core structure of the engine.

Interesting facts and use cases

  • This engine started as a way to learn and enrich my portfolio while I was a university student, circa 2014, represeting over a decade of non-stop development.
  • It's one of the most rewarding projects in terms of the perks you receive should you become a contributor, more here.
  • Godot uses Spartan's TAA, see here
  • Stalker Anomaly has an addon which enchances rendering based on Spartan's source here
  • Jesse Guerrero, a contributor, wrote a book on beginning programming, showcasing Spartan's code, Discord community and the leadership within it.

Are you utilizing any components from the Spartan Engine, or has it inspired aspects of your work? If yes, reach out to me, I'd love to showcase your project.