README.md

    Ash Engine

    Ash Engine is a cross-platform 3D engine (only for learning purpose) based on Qt, OpenGL and Assimp.

    Screenshots

    Requirements

    • Windows 7 x64 or newer, macOS 10.12 or newer, or Ubuntu 16.04
    • A graphics card that supports OpenGL 3.3+

    Features

    • Friendly, simple and convenient GUI.
    • Readable, clear code structure which is easy to expand.
    • Supports reading and saving 3D model files in 40+ formats, including FBX, DXF, Collada, Obj, X, PLY, 3DS, etc.
    • Supports reading and saving the entire project (using the file type *.aeproj defined by this engine)
    • Uses tree structure to describe the scene, supports basic transformation (translation, rotation, scaling) on model and mesh.
    • Supports diffuse maps, specular maps, and normal maps.
    • Supports ambient light, directional light, point light, and spotlight. You can create not more than 8 lights of each type. For each light, you can adjust its color, position, and many other properties.

    User Manual

    Basic User Manuals

    The basic user manuals describe the structure and usage of Ash Engine.

    Basic User Manual (English)

    Basic User Manual (Chinese)

    Advanced User Manuals

    The advanced user manuals cover the implementation of custom functions using API provided by Ash Engine. This requires the user to be familiar with C++ object-oriented programming and some Qt classes (such as QVector3D).

    Note: Read the basic manuals first before you start to read any advanced manual.

    For English Users

    Advanced User Manual 1: Scene Structure (English)

    Advanced User Manual 2: Create a window (English)

    Advanced User Manual 3: Model Loading (English)

    Advanced User Manual 4: Multiple Lights (English)

    Advanced User Manual 5: Basic Transformation (English)

    Advanced User Manual 6: Custom Rendering Loop (English)

    For Chinese Users

    Advanced User Manual 1: Scene Structure (Chinese)

    Advanced User Manual 2: Create a window (Chinese)

    Advanced User Manual 3: Model Loading (Chinese)

    Advanced User Manual 4: Multiple Lights (Chinese)

    Advanced User Manual 5: Basic Transformation (Chinese)

    Advanced User Manual 6: Custom Rendering Loop (Chinese)

    Build from source

    Note: This project was built under Qt 5.9.7. No matter which platform or IDE you use, you must install Qt first.

    Three main platforms are supported:

    • Windows 7 x64 or newer
    • macOS 10.14 (Older versions may work too)
    • Ubuntu 16.04 LTS (Only tested on 16.04, other versions may work too)

    It takes about 3 minutes to build on a laptop with Intel Core i5-5257U (single thread).

    Build Instructions (English)

    Build Instructions (Chinese)

    Future Work

    Rendering

    • DirectX 12
    • Real-time shadow based on depth map
    • Real-time ray tracing using DirectX 12 DXR
    • Deferred rendering
    • SSAO
    • Displacement mapping
    • PBR

    Others

    • More detailed documents for both English and Chinese
    • Implement unit tests using Google Test

    Welcome to contact or join me!

    Email: afterthat97@foxmail.com

    项目简介

    当前项目暂无项目简介

    发行版本 13

    The V1.0.0 Release

    全部发行版

    贡献者 2

    A Alfred Liu @Alfred Liu
    A afterthat97 @afterthat97

    开发语言

    • C++ 93.5 %
    • GLSL 2.6 %
    • Shell 2.3 %
    • QMake 1.3 %
    • C 0.3 %