RapidGL
RapidGL copied to clipboard
Framework for rapid OpenGL demos prototyping
RapidGL
Framework for rapid OpenGL demos prototyping.
This framework consists of two major parts:
-
Core library - which is used as a static library for all examples. Source files are located in
src/core
. -
Demos. Source files are located in
src/demos
.
How to build
After cloning the repository, run one of the .bat scripts to generate Visual Studio 2019/2022 solution:
- setup_vs2019.bat - to generate VS 2019 solution.
- setup_vs2022.bat - to generate VS 2022 solution.
Or run the following command in the root directory to generate project files with the default build system for your system:
cmake -B build
Either of these approaches will create project files in the build directory.
How to add a new demo using Template Project
The following instructions are also located in src/demos/00_template_project/template_project.h
.
To begin creating a new demo using RapidGL framework follow these steps:
- Create new directory in
src/demos/<your_dir_name>
. - Add the following line to
src/demos/CMakeLists.txt
:add_subdirectory(<your_dir_name>)
. - Copy contents of
src/demos/00_template_project
tosrc/demos/<your_dir_name>
. - Change target name of your demo in
src/demos/<your_dir_name>/CMakeLists.txt
fromset(DEMO_NAME "00_template_project")
toset(DEMO_NAME "your_demo_name")
. - (Re-)Run CMake
Notes: After changing class name from e.g. TemplateProject to something else, update main.cpp
in <your_dir_name>
accordingly.
Examples
All of the demos are available in src/demos
.
Template Project
data:image/s3,"s3://crabby-images/9d2a7/9d2a7d0c73fb7c7712100d20c8baada068285457" alt="Template Project"
Simple Triangle
data:image/s3,"s3://crabby-images/51ae6/51ae6ed586c32cc0cdacffe32b862ee5cfbb50ea" alt="Simple Triangle"
Simple 3D
This demo shows how to create camera, load models, generate primitives using built-in functions and add textures for specific objects.
data:image/s3,"s3://crabby-images/81eb9/81eb9bd69617fca802b31d8a980ddd44952f0038" alt="Simple 3D"
Lighting
This demo presents implementation of Blinn-Phong shading model for directional, point and spot lights.
data:image/s3,"s3://crabby-images/b3cde/b3cde3c96cc4a984695598210c046883989fc7eb" alt="Lighting"
Multitextured terrain
This demo presents implementation of multitextured terrain. It uses a blend map (for varying X-Z texturing) and slope based texturing (for texturing the slopes).
data:image/s3,"s3://crabby-images/ef9c2/ef9c24daca69e86c3c9061faa1d3a2e74f3f8ab3" alt="Multitextured terrain"
Toon shading
This demo presents implementation of various toon shading methods (Simple, Advanced, Simple with Rim, Twin Shade) with different outline rendering methods (Stencil, Post-Process).
data:image/s3,"s3://crabby-images/0dcce/0dccecbb743eda008f56ba84afcbcd21cf13aea5" alt="Toon shading"
Simple Fog
Implementation of a simple fog rendering. Three modes are available: linear, exp, exp2.
data:image/s3,"s3://crabby-images/42672/42672648f1f22c35ba491112dd7e4783302f1162" alt="Simple Fog"
Alpha Cutout
This demo shows implementation of an alpha cutout using fragments discarding.
data:image/s3,"s3://crabby-images/269b9/269b938ec25fe8c36bf7ca8c29b5c6a2b21f226e" alt="Alpha Cutout"
Environment mapping
Implementation of dynamic and static environment mapping (light reflection and refraction).
data:image/s3,"s3://crabby-images/93327/93327132df5997ad28f546798d0c7b3d9f97a86d" alt="Environment mapping"
Projected texture
Demo presents projecting a texture onto a surface.
data:image/s3,"s3://crabby-images/69c72/69c727f8f8e515d2f9a343fc943651ea4a2a31ed" alt="Projected texture"
Postprocessing filters
Negative, edge detection (Sobel operator) and Gaussian blur filters demo.
data:image/s3,"s3://crabby-images/ffa90/ffa904648e5be176c57cd08d244c1e5f7083bcf5" alt="Postprocessing filters"
Geometry Shader: Point Sprites
Demo presents generation of quad sprites from points data using Geometry Shader.
data:image/s3,"s3://crabby-images/8b966/8b966eb42114a7981c5d758e6ebb5d79a64ec4d2" alt="Geometry Shader: Point Sprites"
Geometry Shader: Wireframe on top of a shaded model
data:image/s3,"s3://crabby-images/f7e72/f7e726554eb5a7c4677986a520b8eac5d0a6a7df" alt="Geometry Shader: Wireframe on top of a shaded model"
Tessellation - 1D
data:image/s3,"s3://crabby-images/b47fd/b47fd7dd38aea5fc2e53503b01ff603b90a125ad" alt="Tessellation - 1D"
Tessellation - 2D
data:image/s3,"s3://crabby-images/5f863/5f863afeb907b5be179bcb93c716c99d22f905c4" alt="Tessellation - 2D"
PN Triangles Tessellation with Level of Detail
This demo implements Point-Normal tessellation algorithm (see main.cpp for references) with depth based level of detail (NOTE: works for each mesh with vertex normals).
data:image/s3,"s3://crabby-images/933ed/933ed4ca3b229c2a555152521eddc776fc1b9c29" alt="PN Triangles Tessellation with Level of Detail"
Procedural noise textures
data:image/s3,"s3://crabby-images/9a12f/9a12f7eefa4d85d8e25298708b4f43c86810171f" alt="Procedural noise textures"
Surface animation with vertex displacement
data:image/s3,"s3://crabby-images/dd2a8/dd2a82a6cb0186789fc65212f8d77abdb599b85e" alt="Surface animation with vertex displacement"
Simple particle system using Transform Feedback
Available presets: fountain, fire and smoke.
data:image/s3,"s3://crabby-images/7a8b4/7a8b408292f58f7d097fd7ce1343feccf1ce9cc2" alt="Simple particle system using Transform Feedback"
Particle system using instanced meshes with the Compute Shader
data:image/s3,"s3://crabby-images/f2a33/f2a33e1279759912a59e8cc7d1ed9dc0c8e8116a" alt="Particle system using instanced meshes with the Compute Shader"
Mesh skinning
This demo presents simple model animation system using Assimp. There are two skinning methods available: Linear Blend Skinning and Dual Quaternion Blend Skinning.
data:image/s3,"s3://crabby-images/e51ab/e51abe2d2744ae236516d3468125d0de0378bdb8" alt="Mesh skinning"
Order Independent Transparency (OIT) with MSAA
Order Independent Transparency using linked lists (per pixel) with MSAA.
data:image/s3,"s3://crabby-images/8d146/8d146d593e40988c4575943009e72348a0d35d4f" alt="Order Independent Transparency (OIT)"
Physically Based Rendering (PBR)
Including directional and punctual lights (spot and point) with square falloff attenuation. The demo supports textured and non-textured objects.
data:image/s3,"s3://crabby-images/270ce/270ce510a4d39f92b65d5b06c4adf8ce79dbdc73" alt="Physically Based Rendering (PBR)"
Geometry Shader: Face Extrusion
data:image/s3,"s3://crabby-images/c14b1/c14b16ffd9104fefafe390663922b1d9c2d1b060" alt="Physically Based Rendering (PBR)"
Percentage Closer Soft Shadows (PCSS)
data:image/s3,"s3://crabby-images/b6a8a/b6a8a6da1cc53621a333e952c6ea3ef87e3ad953" alt="Percentage Closer Soft Shadows"
Cascaded Percentage Closer Soft Shadows (CPCSS)
data:image/s3,"s3://crabby-images/56698/5669860d8aa56648acb7bad3c3cbc4921ec8118b" alt="Cascaded Percentage Closer Soft Shadows"
Bloom
Bloom implementation based on Call of Duty: Advanced Warfare Jimenez14. Implemented using Compute Shaders with shared memory utilization for improved performance. Full bloom pass (1920x1080) takes ~0.75ms on NVidia GTX 1660 Ti with Max-Q Design (according to NVIDIA Nsight Graphics).
data:image/s3,"s3://crabby-images/ed934/ed93491f95909a0d81b50335c4cc514d9432c514" alt="Bloom implementation based on Call of Duty: Advanced Warfare."
Clustered Forward Shading
Clustered Forward Shading implementation based on Clustered Deferred and Forward Shading (2012) (Ola Olsson, Markus Billeter, Ulf Assarsson) and Jeremiah van Oosten's DX12 demo.
For light culling, I used view aligned AABB grid. During the lighting stage, only the visible clusters are taken into account (it greatly improves the performance as we limit the searching domain).
The demo is able to render ~100k lights at interactive frame rates (> 30FPS) on NVidia GTX 1660 Ti with Max-Q Design at 1920x1080 resolution.
To further improve the performance, you may look into adding lights BVH structure as described in O. Olsson's paper. Jeremiah van Oosten's DX12 demo includes the fully optimized version of clustered shading algorithm. I highly recommend looking into it.
19/07/2023 update: The demo now also supports the LTC Area Lights based on Eric Heitz's paper Real-Time Polygonal-Light Shading with Linearly Transformed Cosines (2016). The area lights are also being culled by the clustered shading algorithm.
data:image/s3,"s3://crabby-images/a2b6f/a2b6fc6c7061a8e99114aac54a0e4d70f4d64c99" alt="Clustered Forward Shading implementation."
data:image/s3,"s3://crabby-images/64a1f/64a1f1bea8aa5628d5610cf1fcf42dce65464e82" alt="Clustered Forward Shading implementation with Area Lights."