项目作者: flingengine

项目描述 :
A Vulkan game engine with a focus on data oriented design
高级语言: C++
项目地址: git://github.com/flingengine/FlingEngine.git
创建时间: 2019-05-21T01:08:44Z
项目社区:https://github.com/flingengine/FlingEngine

开源协议:MIT License

下载


Fling Engine Logo

The Fling Engine aims to be a cross platform Vulkan game engine that will experiment with the following:

  • Low-level engine systems such as render API abstraction, file systems, and custom allocators.
  • Multithreaded engine architecture
  • The Vulkan graphics API for real time rendering

Build Status
Build status
Open Source Helpers
GitHub license
Work in progress badge
Discord Chat

Getting Started

There are a few basic steps to compiling Fling on your platform.

CMake 3.13 or higher!

This project requires CMake 3.13 or higher, you can install it here.

For Linux

This project uses GLFW, so you will need to install those libraries to your machine.
GLFW also depends on having Doxygen, so you may want to have that as well.

Ubuntu:

  1. sudo apt-get update
  2. sudo apt-get install doxygen
  3. sudo apt-get install -y libglm-dev libxcb-dri3-0 libxcb-present0
  4. sudo apt-get install -y libpciaccess0 libpng-dev libxcb-keysyms1-dev
  5. sudo apt-get install -y libxcb-dri3-dev libx11-dev libmirclient-dev
  6. sudo apt-get install -y libwayland-dev libxrandr-dev
  7. sudo apt-get install -y libglfw3-dev
  8. sudo apt-get install -y xorg-dev

Vulkan SDK

Obviously this project is build using Vulkan, so you will need to install it before compiling
or running the program.

You can download the SDK from the LunarG website here.

If you are having trouble with the Vulkan SDK then check out some of these resources:

Init.bat and Init.sh

After installing the SDK, you can simply run one of the provided scripts.

Running either one of these scripts will simply get all submodules and external libraries
that the engine uses and create a folder called build. The build folder will have your
platform specific build files (Visual Studio, Makefiles, etc).

Packaging a project

For ease of development and iteration the file paths to Assets (shaders, textures, models, etc) are all
absolute paths generated by CMake. If you want to have a copy of your executeable with asset paths relative
to the program, then generate your project files with CMake with this flag:

  1. cmake -DDEFINE_SHIPPING=ON -B build .

Notice the -DDEFINE_SHIPPING option is set to ON. This sets a definiton that you can use in C++:

  1. #ifdef FLING_SHIPPING
  2. // Do some nice stuff
  3. #else
  4. // Do non-shipping code, perhaps with a lot of log messages
  5. #endif

Wanna contribute?

If you have any contributions or fixes that you want to contribute, then feel free to open
an issue or a pull request! I’m happy to talk about the project, so feel free to reach out
to me on Twitter or here on GitHub. Eventually a
goal is to have some more specific PR templates/coding standards but for now that is not a
priority.

Branching Strategy

We use a pretty basic branching strategy. Make a feature branch off of Main for something like “add-support-for-x”, and then that feature is done and tested create a pull request to get it into Main.

We will create stable “Release” branches and tag them accordingly with stable versions of the build.

Cool Resources

Some great resources are the
Vulkan Tutorial and
SaschaWillems‘s repo with different Vulkan examples