Shadow mapping!
It& #39;s a technic for adding shadows to a game.
 https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐งต" title="Thread" aria-label="Emoji: Thread">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐งต" title="Thread" aria-label="Emoji: Thread">
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    It& #39;s a technic for adding shadows to a game.
                        
                        
                        Shadow maps save info about which areas of the scene are in light and which are in shadow. This data is saved into a texture called a shadow map.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        If the scene and lights don& #39;t change we can pre bake all this info and use the same map for every frame! Sometimes this is called a light map and extra info can get packed in like light color.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        If we have moving characters or lights we need to rebuild the map
 https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign"> every
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign"> every  https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign"> single
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign"> single  https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign"> frame
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign"> frame  https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Clapping hands sign" aria-label="Emoji: Clapping hands sign">
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        So how do we work out which area is in shadow?
We reuse the renderer and let the GPU do its thing.
                    
                                    
                    We reuse the renderer and let the GPU do its thing.
                        
                        
                        Reset the shadow map to be full shadow. Put a camera at the light source and render everything we & #39;see& #39; white. Anything the light can& #39;t see is shadow.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        If we have more lights we need to repeat the process and combine the shadow maps.
16 lights, 16 extra renders.
                    
                                    
                    16 lights, 16 extra renders.
                        
                        
                        Now we have our shadow map we can pump it into the shaders and we can darken all the shadow areas.
Awesome! https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Smiling face with sunglasses" aria-label="Emoji: Smiling face with sunglasses">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Smiling face with sunglasses" aria-label="Emoji: Smiling face with sunglasses">
                        
                        
                        
                        
                                                
                    
                    
                                    
                    Awesome!
                        
                        
                        Now we have a problem  https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐ฌ" title="Grimacing face" aria-label="Emoji: Grimacing face">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐ฌ" title="Grimacing face" aria-label="Emoji: Grimacing face">
The areas close to the camera need to be high resolution so we don& #39;t see a jagged pixel boundary between light and shadow.
                    
                                    
                    The areas close to the camera need to be high resolution so we don& #39;t see a jagged pixel boundary between light and shadow.
                        
                        
                        When we increase the resolution our shadow map renders are taking too long and using up all the GPU memory  https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐ฑ" title="Face screaming in fear" aria-label="Emoji: Face screaming in fear">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐ฑ" title="Face screaming in fear" aria-label="Emoji: Face screaming in fear">
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        One solution is to split the shadow maps into chunks with different resolutions. High res close to the camera and low res when far from the camera. These are called cascading shadow maps.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Fantastic, we are putting our shadow pixel budget to good use. Spending it mostly up front, close to the camera. There is just one issue left....
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        At the boundary between map cascades we have a small artifact. We can make it less noticeable by pushing the boundary further away from the camera, but if we do that we waste precious pixels and make the close up shadows look worse.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Best thing to do is sit down and tweak the distance by hand until you find the trade-off you can live with.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Remember 99.995% of your players are not looking at your game in slow motion on 400% zoom. Close enough is good enough.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Notes:
If you are using point lights you often need to do even more render passes to cover all the directions the light can shine.
                    
                                    
                    If you are using point lights you often need to do even more render passes to cover all the directions the light can shine.
                        
                        
                        This is describing a foward render pipeline, deferred pipelines are a while other can of worms  https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Grinning face with smiling eyes" aria-label="Emoji: Grinning face with smiling eyes">
https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐" title="Grinning face with smiling eyes" aria-label="Emoji: Grinning face with smiling eyes">
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        References:
https://docs.unity3d.com/Manual/Shadows.html
https://docs.unity3d.com/Manual/Sh... href=" http://blog.stephenpetrany.com/a-study-of-shadows-in-photoshop-direct-shadows/
https://blog.stephenpetrany.com/a-study-o... href=" https://docs.nvidia.com/gameworks/content/gameworkslibrary/graphicssamples/opengl_samples/cascadedshadowmapping.htm">https://docs.nvidia.com/gameworks...
                    
                
                https://docs.unity3d.com/Manual/Shadows.html
https://docs.unity3d.com/Manual/Sh... href=" http://blog.stephenpetrany.com/a-study-of-shadows-in-photoshop-direct-shadows/
https://blog.stephenpetrany.com/a-study-o... href=" https://docs.nvidia.com/gameworks/content/gameworkslibrary/graphicssamples/opengl_samples/cascadedshadowmapping.htm">https://docs.nvidia.com/gameworks...
 
                         Read on Twitter
Read on Twitter " title="Shadow mapping!It& #39;s a technic for adding shadows to a game.https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐งต" title="Thread" aria-label="Emoji: Thread">" class="img-responsive" style="max-width:100%;"/>
" title="Shadow mapping!It& #39;s a technic for adding shadows to a game.https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐งต" title="Thread" aria-label="Emoji: Thread">" class="img-responsive" style="max-width:100%;"/>
                             
                             
                             The areas close to the camera need to be high resolution so we don& #39;t see a jagged pixel boundary between light and shadow." title="Now we have a problem https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐ฌ" title="Grimacing face" aria-label="Emoji: Grimacing face">The areas close to the camera need to be high resolution so we don& #39;t see a jagged pixel boundary between light and shadow." class="img-responsive" style="max-width:100%;"/>
The areas close to the camera need to be high resolution so we don& #39;t see a jagged pixel boundary between light and shadow." title="Now we have a problem https://abs.twimg.com/emoji/v2/... draggable="false" alt="๐ฌ" title="Grimacing face" aria-label="Emoji: Grimacing face">The areas close to the camera need to be high resolution so we don& #39;t see a jagged pixel boundary between light and shadow." class="img-responsive" style="max-width:100%;"/>
                             
                             
                             
                                     
                                    