Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/alaingalvan/vulkan-seed

πŸŒ‹πŸŒ± A Vulkan starter repo that you could use to get the ball rolling.
https://github.com/alaingalvan/vulkan-seed

crosswindow glm starter vulkan

Last synced: about 2 months ago
JSON representation

πŸŒ‹πŸŒ± A Vulkan starter repo that you could use to get the ball rolling.

Awesome Lists containing this project

README

        

![Cover Art](https://alain.xyz/blog/raw-vulkan/assets/cover.jpg)

# Vulkan Seed

[![cmake-img]][cmake-url]
[![License][license-img]][license-url]

A Vulkan repo you can use to get started with your own renderer.

## Setup

First install:

- [Git](https://git-scm.com/)

- [CMake](https://cmake.org)

- An IDE such as [Visual Studio](https://visualstudio.microsoft.com/downloads/), [XCode](https://developer.apple.com/xcode/), or a compiler such as [GCC](https://gcc.gnu.org/).

Then type the following in your [terminal](https://hyper.is/).

```bash
# πŸ‘ Clone the repo
git clone https://github.com/alaingalvan/vulkan-seed --recurse-submodules

# πŸ’Ώ go inside the folder
cd vulkan-seed

# πŸ‘― If you forget to `recurse-submodules` you can always run:
git submodule update --init

# πŸ‘· Make a build folder
mkdir build
cd build

# πŸ–ΌοΈ To build your Visual Studio solution on Windows x64
cmake .. -A x64

# 🍎 To build your XCode project On Mac OS for Mac OS
cmake .. -G Xcode

# πŸ“± To build your XCode project on Mac OS for iOS / iPad OS / tvOS / watchOS
cmake .. -G Xcode -DCMAKE_SYSTEM_NAME=iOS

# 🐧 To build your .make file on Linux
cmake ..

# πŸ€– To build your Android Studio project for Android
cmake .. \
-DCMAKE_TOOLCHAIN_FILE=$NDK/build/cmake/android.toolchain.cmake \
-DANDROID_ABI=$ABI \
-DANDROID_NATIVE_API_LEVEL=$MINSDKVERSION \
-DXWIN_OS=ANDROID

# πŸ”¨ Build on any platform:
cmake --build .
```

> Refer to [this blog post on designing C++ libraries and apps](https://alain.xyz/blog/designing-a-cpp-library) for more details on CMake, Git Submodules, etc.

## Project Layout

As your project becomes more complex, you'll want to separate files and organize your application to something more akin to a game or renderer, check out this post on [game engine architecture](https://alain.xyz/blog/game-engine-architecture) and this one on [real time renderer architecture](https://alain.xyz/blog/realtime-renderer-architectures) for more details.

```bash
β”œβ”€ πŸ“‚ external/ # πŸ‘Ά Dependencies
β”‚ β”œβ”€ πŸ“ crosswindow/ # πŸ–ΌοΈ OS Windows
β”‚ β”œβ”€ πŸ“ crosswindow-graphics/ # 🎨 Vulkan Surface Creation
β”‚ └─ πŸ“ glm/ # βž• Linear Algebra
β”œβ”€ πŸ“‚ src/ # 🌟 Source Files
β”‚ β”œβ”€ πŸ“„ Utils.h # βš™οΈ Utilities (Load Files, Check Shaders, etc.)
β”‚ β”œβ”€ πŸ“„ Renderer.h # πŸ”Ί Triangle Draw Code
β”‚ β”œβ”€ πŸ“„ Renderer.cpp # -
β”‚ └─ πŸ“„ Main.cpp # 🏁 Application Main
β”œβ”€ πŸ“„ .gitignore # πŸ‘οΈ Ignore certain files in git repo
β”œβ”€ πŸ“„ CMakeLists.txt # πŸ”¨ Build Script
β”œβ”€ πŸ“„ license.md # βš–οΈ Your License (Unlicense)
└─ πŸ“ƒreadme.md # πŸ“– Read Me!
```

[cmake-img]: https://img.shields.io/badge/cmake-3.6-1f9948.svg?style=flat-square
[cmake-url]: https://cmake.org/
[license-img]: https://img.shields.io/:license-mit-blue.svg?style=flat-square
[license-url]: https://opensource.org/licenses/MIT