Introduction Typescript Engine Architecture Multiple Render Passes Architecture Camera Frustum Culling Shader Composition WebGPU API No Optional Shader Bindings Depth+Stencil Configuration as Part of the Pipeline State Object Limited Sampler Support in Compute Shaders Lack of Proper Texture Blit Encoder A Trip Through the Rendering Pipeline Cascaded Shadow Maps G-Buffer Render Pass SSAO Pass Lighting Directional + Ambient + Shadow Lighting Pass Point Lights Lighting Pass Point Lights Volume Culling via Stencil Mask Pass Skybox Render Pass Screen Space Reflections Render Pass Linear Tracing Method Hi-Z Tracing Method Hi-Z Pass Temporal Anti-Aliasing (TAA) Resolve Render Pass Rendering the Scene With Jittering Resolve Update History Render Result Bloom Pass Present Render Pass Managing Performance Conclusion
For some time now I have been working on rendering the famous Sponza model with the emerging WebGPU standard, mainly as a personal challenge to get better with the API and to try different rendering techniques. Here is a screenshot of it running in Google Chrome on a M3 MacBook Pro: