basic-graphics-samples
basic-graphics-samples copied to clipboard
Basic graphics samples using Magma library and Vulkan graphics API
Basic C++ sample usages of Magma library and Vulkan graphics API
Cloning
To clone this repository with external submodules:
git clone --recursive https://github.com/vcoda/basic-graphics-samples.git
or clone this repository only and update submodules manually:
git clone https://github.com/vcoda/basic-graphics-samples.git
cd basic-graphics-samples
git submodule update --init --recursive
Build tools and SDK
Windows
Check that VK_SDK_PATH environment variable is present after SDK installation:
echo %VK_SDK_PATH%
Shaders are automatically compiled using glslangValidator as Custom Build Tool. If you use Visual Studio newer than 2017, change the SDK version in the project property pages or by right-clicking the solution and selecting "Retarget solution".
Linux (Ubuntu)
Install GCC and Git (if not available):
sudo apt update
sudo apt install gcc
sudo apt install g++
sudo apt install make
sudo apt install git
Install XCB headers and libraries:
sudo apt install xcb
sudo apt install libxcb-icccm4-dev
For Xlib, install X11 headers and libraries (optional):
sudo apt install libx11-dev
Go to the directory where .run file was saved:
chmod ugo+x vulkansdk-linux-x86_64-<version>.run
./vulkansdk-linux-x86_64-<version>.run
cd VulkanSDK/<version>/
source ./setup-env.sh
Check that Vulkan environment variables are present:
printenv | grep Vulkan
Systems with AMD graphics hardware
Check whether AMDGPU-PRO stack is installed:
dpkg -l amdgpu-pro
If not, download and install it from an official web page:
NOTE: You have to make sure that graphics driver is compatible with current Linux kernel. Some of the driver's libraries are compiled against installed kernel headers, and if kernel API changed since driver release, compilation will fail and driver become malfunction after reboot. I used a combination of AMDGPU-PRO Driver Version 17.10 and Ubuntu 16.04.2 with kernel 4.8.0-36. Also disable system update as it may upgrade kernel to the version that is incompatible with installed graphics driver. Successfull AMDGPU-PRO installation should look like this:
Loading new amdgpu-pro-17.10-446706 DKMS files...
First Installation: checking all kernels...
Building only for 4.8.0-36-generic
Building for architecture x86_64
Building initial module for 4.8.0-36-generic
Done.
Forcing installation of amdgpu-pro
After reboot check that driver stack is installed:
dpkg -l amdgpu-pro
Desired=Unknown/Install/Remove/Purge/Hold
| Status=Not/Inst/Conf-files/Unpacked/halF-conf/Half-inst/trig-aWait/Trig-pend
|/ Err?=(none)/Reinst-required (Status,Err: uppercase=bad)
||/ Name Version Architecture Description
+++-===============================-====================-====================-====================================================================
ii amdgpu-pro 17.10-446706 amd64 Meta package to install amdgpu Pro components.
Systems with Nvidia graphics hardware
TODO
Building
To build all samples, go to the repo root directory and run make script:
make -j<N>
where N is the number of threads to run with multi-threaded compilation. First, magma and quadric libraries will be built, then samples. To build a particular sample, you can build dependencies separately, then go to the sample's directory and run make script:
cd 01-clear
make
./01-clear
There is debug build by default. For release build, set DEBUG variable to 0, e. g.:
make magma DEBUG=0 -j<N>
Android
macOS and iOS
Samples
01 - Clear framebuffer
data:image/s3,"s3://crabby-images/00565/00565f559bc5e2d3acf54aa78b0da0a12db39285" alt=""
02 - Triangle
data:image/s3,"s3://crabby-images/05e90/05e90c74299e335064cf4e857737212780fb7ae8" alt=""
03 - Vertex buffer
data:image/s3,"s3://crabby-images/6401c/6401ce79a1658bfec844ffede2d900a02c6d2b41" alt=""
04 - Vertex transform
data:image/s3,"s3://crabby-images/adfdc/adfdcb1e0a15cc38194e23e8c4924a8313efad46" alt=""
05 - Mesh
data:image/s3,"s3://crabby-images/b74b3/b74b3adef428f439fdbcee891e36281bb8b5d596" alt=""
06 - Texture
data:image/s3,"s3://crabby-images/08a92/08a92b591f605db849c622131839cdd3f7a68067" alt=""
07 - Texture array
data:image/s3,"s3://crabby-images/11fe4/11fe4ab5db89e664b2467df365f3b575e67a5591" alt=""
08 - Cubemap texture
data:image/s3,"s3://crabby-images/105e2/105e28290dd0f40981f8f51d77171192e4112ca9" alt=""
09 - Volume texture
data:image/s3,"s3://crabby-images/0d705/0d705887fcd802e7bc54dd50378a151ab3284d90" alt=""
10.a - Render to texture
data:image/s3,"s3://crabby-images/19e73/19e73fb07928a18d4d74780bc404c86c4b3d5f05" alt=""
10.b - Render to multisample texture
data:image/s3,"s3://crabby-images/70d13/70d13a8b8446b59f9191af0d1731e5f1f6aad431" alt=""
11 - Occlusion query
data:image/s3,"s3://crabby-images/c4869/c486960b1f9a9f27cda080e857bbfcb165776cb5" alt=""
12 - Alpha blending
data:image/s3,"s3://crabby-images/d59a3/d59a3cedede181cccdcd2a17da21c7b9638bd6d3" alt=""
13 - Specialization constants
data:image/s3,"s3://crabby-images/5678a/5678a4d3f62c7fdd83e7ed4c4238af3fc19c600f" alt=""
14 - Push constants
data:image/s3,"s3://crabby-images/2965d/2965db7f64994c566ef8214214ac552b5a4f8ca0" alt=""
15 - Particles
data:image/s3,"s3://crabby-images/8c96a/8c96a6078b0e53c54cf7784b50db6c79e9c2298d" alt=""
16 - Immediate mode
data:image/s3,"s3://crabby-images/b7812/b7812460ca2808e23e3e860349638be33242489c" alt=""
17 - ShaderToy
data:image/s3,"s3://crabby-images/76171/76171c5b983061b9d84505a101cb388314c3e41d" alt=""
18 - Compute shader
data:image/s3,"s3://crabby-images/280dd/280dd2a74993dfa1d2edf54e879ee86a3b63980f" alt=""
Known issues
- vkCreateSwapchainKHR() may fail on Linux due to unresolved issues with alignment.
Credits
This framework uses a few third-party libraries:
-
Microsoft DirectXMath
Linear algebra library with fantastic CPU optimizations using SSE2/SSE3/SSE4/AVX/AVX2 intrinsics.
I wrote a simple wrapper over it to make its usage more OOP friendly. -
Gliml
Minimalistic image loader library by Andre Weissflog.