3DEngine 3.1.0

dotnet add package 3DEngine --version 3.1.0                
NuGet\Install-Package 3DEngine -Version 3.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="3DEngine" Version="3.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add 3DEngine --version 3.1.0                
#r "nuget: 3DEngine, 3.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install 3DEngine as a Cake Addin
#addin nuget:?package=3DEngine&version=3.1.0

// Install 3DEngine as a Cake Tool
#tool nuget:?package=3DEngine&version=3.1.0                

Logo License: MIT

3D Engine

Get it on the Microsoft Store
Documentation
Discord

Overview

The 3D Engine is currently in an early stage of development and is not yet equipped with the essential features required for a production-ready game engine. However, a clear and forward-looking development roadmap has been established, with active work being done to implement advanced systems such as virtualized geometry and radiance cascades for fully dynamic global illumination. As development progresses, I plan to foster a community starting next year, with the aim of building a C# game engine that integrates seamlessly with Unity workflows. With your support, we can create a powerful and user-friendly engine, complete with an editor, that meets the demands of modern game development.

Key Technologies

Windows App SDK

  • Use the WinAppSDK to create beautiful, modern apps for Windows 11.

Vortice.Windows

  • Vortice.Windows provides bindings for key Windows libraries including:
    • DXGI, WIC, DirectWrite, Direct2D, Direct3D9, Direct3D11, Direct3D12, XInput, XAudio2, X3DAudio, DirectInput, DirectStorage, DirectML, UIAnimation, and DirectSound.

Entity Component System (ECS)

  • ECS is a design pattern for high-performance and flexible game development. It emphasizes separation of data from behavior and supports the "composition over inheritance" principle, improving performance and code reusability.

Universal Scene Description (OpenUSD / USD.NET)

  • OpenUSD is a framework for interchange of 3D computer graphics data. The framework focuses on collaboration, non-destructive editing, and enabling multiple views and opinions about graphics data.

Sample Projects

Voxel Sandbox

A 3D Engine sample project demonstrating the capabilities of the 3D Engine. Voxel Sandbox implements the following features:

  • Chunk Generation: Procedurally generates voxel-based chunks for an expansive world.
  • Noise Sampling: Utilizes noise algorithms to create realistic terrain variations.
  • Mesh Generation: Dynamically generates meshes based on voxel data for efficient rendering.
  • Character Controller: Implements a responsive character controller for player movement and interaction.
  • Optimized Shader: Features custom shaders optimized for performance and and targeted for voxels and low memory usage.

All components are written in C#, showcasing how to leverage the 3D Engine's functionalities to build a fully-featured application.

NuGet Package

3DEngine NuGet Package:

Install the package via NuGet Package Manager for integration into your project.

dotnet new console -n Project
cd Project
dotnet add package 3DEngine
dotnet add package Costura.Fody
./Project.csproj

Setup project:

<Project Sdk="Microsoft.NET.Sdk">
    <PropertyGroup>
        <OutputType>WinExe</OutputType>
        <TargetFramework>net8.0-windows10.0.22621.0</TargetFramework>
        <ImplicitUsings>enable</ImplicitUsings>
        <SatelliteResourceLanguages>en</SatelliteResourceLanguages>
        <PlatformTarget>x64</PlatformTarget>
        <PublishAot>true</PublishAot>
    </PropertyGroup>

    <ItemGroup>
      <None Remove="FodyWeavers.xml" />
    </ItemGroup>

    <ItemGroup>
        <PackageReference Include="3DEngine" Version="3.1.0" />
        <PackageReference Include="Costura.Fody" Version="5.7.0">
          <PrivateAssets>all</PrivateAssets>
        </PackageReference>
    </ItemGroup>

    <ItemGroup>
        <Content Update="$(NuGetPackageRoot)\3dengine\3.1.0\contentFiles\any\net8.0-windows10.0.22621\Assets\Resources\**\*">
            <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
        </Content>
    </ItemGroup>

    <ItemGroup>
      <None Update="Assets\Generators\FileNamesEnumGenerator.tt">
        <Generator>TextTemplatingFileGenerator</Generator>
        <LastGenOutput>FileNamesEnumGenerator.cs</LastGenOutput>
      </None>
    </ItemGroup>
    
    <ItemGroup>
      <Service Include="{508349b6-6b84-4df5-91f0-309beebad82d}" />
    </ItemGroup>
    
    <ItemGroup>
      <Compile Update="Assets\Generators\FileNamesEnumGenerator.cs">
        <DesignTime>True</DesignTime>
        <AutoGen>True</AutoGen>
        <DependentUpon>FileNamesEnumGenerator.tt</DependentUpon>
      </Compile>
    </ItemGroup>
</Project>

Ensure "PreserveNewest" is set for files in the Assets folder in Visual Studio. Replace the Path to the NuGet Package 3DEngine\3.1.0

Setup program:

class Program
{
    [STAThread]
    private static void Main() =>
        new Engine.Program().Run(
            config: Engine.Config.GetDefault(
              windowCommand: Engine.WindowCommand.Show,
              presentInterval: Engine.PresentInterval.Immediate,
              multiSample: Engine.MultiSample.x4,
              resolutionScale: 1,
              title: "3D Engine",
              width: 2560, height: 1440,
              renderGUI: true, defaultBoot: true),
            initialization: () => 
              Engine.Kernel.Instance.SystemManager.MainEntityManager.CreateEntity().AddComponent<GameManager>(),
            frame: () => { });
}

Example script:

using System;
using System.Collections;
using System.Numerics;

using Engine;
using Engine.Buffer;
using Engine.Components;
using Engine.DataStructures;
using Engine.ECS;
using Engine.Editor;
using Engine.Framework;
using Engine.Graphics;
using Engine.GUI;
using Engine.Helper;
using Engine.Runtime;
using Engine.Utilities;

public class Example : Component
{
    [ToolTip("This is a ToolTip")]
    [Show]
    private string _visibleString = "This field is private";
    [Hide]
    public string HiddenString = "This field is public";
    [ShowOnly]
    public string ShowOnlyString = "This string is not editable";
    public int Int;
    public float Float;
    public Vector2 Vector2;
    public Vector3 Vector3;
    public Vector4 Vector4;
    [Slider(1, 100)]
    public float Slider;
    public bool Bool;
    [If("Bool", "True")]
    [ShowOnly]
    public string IfField = "This field is only visible if the bool is true";
    [IfNot("Bool", "True")]
    [ShowOnly]
    public string IfNotField = "This field is only visible if the bool is not true";
    [Color]
    public Vector4 Color;
    public Entity? _Entity;
    [Space]
    [Header("Header")]
    public event Action? Event;

    // This is the base function of OnRegister.
    public override void OnRegister() =>
        ScriptSystem.Register(this);
      
    public override void OnAwake() { }
    public override void OnStart() { }
    public override void OnUpdate() { }
    public override void OnLateUpdate() { }
    public override void OnFixedUpdate() { }
    public override void OnRender() { }
    public override void OnGUI() { }
    public override void OnDestroy() { }
}

Example usage:

Engine.Loader.ModelLoader.LoadFile(Engine.ModelFiles.Model);
Engine.Loader.ModelLoader.LoadFile(Engine.Utilities.AssetPaths.MESHES + "Model.obj");

Engine.Loader.ImageLoader.LoadFile(Engine.TextureFiles.TextureAtlas);
Engine.Loader.ImageLoader.LoadFile(Engine.Utilities.AssetPaths.TEXTURES + "Texture.png");

Engine.Kernel.Instance.Context.CreateShader(Engine.Utilities.AssetPaths.SHADERS + "Shader");
Engine.Kernel.Instance.Context.CreateComputeShader(Engine.Utilities.AssetPaths.COMPUTESHADERS + "ComputeShader");

Entity.AddComponent<Example>();

Entity.Manager.CreateEntity(name: "Controller").AddComponent<PlayerController>().Initialize(this);
Entity.Manager.CreateEntity(name: "Sky").AddComponent<DefaultSky>().Initialize();

var mesh = Entity.Manager.CreateEntity().AddComponent<Mesh>();

mesh.SetMeshData(ModelFiles.Model);
mesh.SetMeshData(Assets.Meshes["Model.obj"]);
mesh.SetMeshData(vertices, indices, positions, new InputLayoutHelper().AddPosition3D().AddUV());

mesh.SetRootSignature();
mesh.SetRootSignature(new RootSignatureHelper().AddConstantBufferView(2).AddShaderResourceViewTable());

mesh.SetMaterialTextures(TextureFiles.Texture);
mesh.SetMaterialTextures(textureEntries: [new("Texture.png", 0)]);

mesh.SetMaterialPipeline(ShaderFiles.Shader);
mesh.SetMaterialPipeline("Shader");

Engine.Utilities.Output.Log(Entity.Transform.Position);

if (Input.GetKey(Key.Escape, InputState.Down))
{
    PAUSED = !PAUSED;

    if (PAUSED)
        Input.SetMouseLockState(MouseLockState.Unlocked);
    else
        Input.SetMouseLockState(MouseLockState.LockedInvisible, 0.5, 0.5);
}

if (!PAUSED)
    Input.SetCursorIcon(SystemCursor.IDC_CROSS);

Solution Structure

The 3D Engine repository includes:

  • 3DEngine (Package)
  • Editor
  • Engine

You can build the 3DEngine (Package) for both the Editor and Engine as a MSIX Application or the Engine as a portable Win32 Application.

Upcoming Features and Development Roadmap

  • USD Integration
  • Materials
  • Render Textures
  • Compute Shaders
  • Post Processing
  • Gizmos
  • Asynchronous Reprojection
  • Radiance Cascade (Alexander Sannikov)
  • Virtualized Geometry (Nano Tech, Chris K)
  • Networking
  • Spatial Audio
  • PhysX 5
  • Export Build to the Xbox Platform

Build Instructions

To compile the 3D Engine, ensure you have Visual Studio 2022 with the following components:

Screenshots

3D Engine Layout 1 2 3 4 5 6 7 8 9 10 13

Product Compatible and additional computed target framework versions.
.NET net8.0-windows10.0.22621 is compatible.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.1.0 188 10/30/2024
3.0.99 164 10/30/2024
3.0.98 164 10/30/2024
3.0.97 166 10/29/2024
3.0.96 174 10/29/2024
3.0.95 150 10/29/2024
3.0.94 150 10/29/2024
3.0.93 148 10/29/2024
3.0.92 157 10/29/2024
3.0.91 148 10/29/2024
3.0.90 159 10/29/2024
3.0.89 191 10/29/2024
3.0.88 158 10/29/2024
3.0.87 163 10/29/2024
3.0.86 154 10/29/2024
3.0.85 136 10/29/2024
3.0.84 144 10/29/2024
3.0.83 153 10/29/2024
3.0.82 153 10/27/2024
3.0.81 140 10/26/2024
3.0.80 156 10/26/2024
3.0.79 137 10/25/2024
3.0.78 160 10/24/2024
3.0.77 130 10/24/2024
3.0.76 134 10/24/2024
3.0.75 156 10/24/2024
3.0.74 157 10/23/2024
3.0.73 165 10/23/2024
3.0.72 182 10/23/2024
3.0.71 147 10/23/2024
3.0.70 141 10/21/2024
3.0.69 163 10/21/2024
3.0.68 160 10/21/2024
3.0.67 157 10/21/2024
3.0.66 132 10/21/2024
3.0.65 143 10/21/2024
3.0.64 142 10/21/2024
3.0.63 162 10/21/2024
3.0.62 144 10/21/2024
3.0.61 145 10/21/2024
3.0.60 150 10/21/2024
3.0.59 146 10/21/2024
3.0.58 126 10/21/2024
3.0.57 143 10/21/2024
3.0.56 155 10/21/2024
3.0.55 165 10/21/2024
3.0.54 169 10/19/2024
3.0.53 161 10/19/2024
3.0.52 220 10/19/2024
3.0.51 201 10/19/2024
3.0.50 237 10/18/2024
3.0.49 155 10/18/2024
3.0.48 179 10/17/2024
3.0.47 158 10/17/2024
3.0.46 139 10/17/2024
3.0.45 167 10/17/2024
3.0.44 174 10/17/2024
3.0.43 166 10/17/2024
3.0.42 155 10/17/2024
3.0.41 177 10/17/2024
3.0.40 161 10/17/2024
3.0.39 154 10/9/2024
3.0.38 167 10/9/2024
3.0.37 133 10/7/2024
3.0.36 129 10/7/2024
3.0.35 130 10/7/2024
3.0.34 144 10/3/2024
3.0.33 154 10/1/2024
3.0.32 168 10/1/2024
3.0.31 170 9/30/2024
3.0.30 139 9/30/2024
3.0.29 136 9/30/2024
3.0.28 144 9/28/2024
3.0.27 164 9/27/2024
3.0.26 170 9/26/2024
3.0.25 154 9/25/2024
3.0.24 143 9/25/2024
3.0.23 149 9/22/2024
3.0.21 153 9/19/2024
3.0.19 156 9/19/2024
3.0.18 151 9/18/2024
3.0.17 155 9/18/2024
3.0.16 153 9/18/2024
3.0.15 220 9/17/2024
3.0.14 161 9/17/2024
3.0.13 163 9/17/2024
3.0.12 223 9/15/2024
3.0.11 193 9/15/2024
3.0.10 175 9/15/2024
3.0.9 166 9/15/2024
3.0.8 177 9/15/2024
3.0.7 172 9/15/2024
3.0.6 165 9/15/2024
3.0.5 179 9/15/2024
3.0.4 158 9/15/2024
3.0.3 174 9/15/2024
3.0.2 184 9/11/2024
3.0.1 194 9/11/2024
3.0.0 191 9/8/2024
2.2.2 174 8/11/2024
2.0.2 344 3/7/2024
2.0.1 280 2/25/2024
2.0.0 328 2/25/2024
1.0.7 784 10/20/2023
1.0.6 264 10/20/2023
1.0.5 324 10/19/2023
1.0.4 309 10/18/2023
1.0.3 352 10/18/2023
1.0.2 308 10/18/2023
1.0.1 379 10/18/2023
1.0.0 348 10/13/2023