this time i'm breaking down my water shader!
#gamedev #indiedev #shaders #madewithunity
there are lots of good stylized water tutorials out there, like this one by @minionsart : so i'm just going focus on what's different
data:image/s3,"s3://crabby-images/0dbee/0dbee81ecd92042e2ac5c649208e02a9a3696b6f" alt=""
data:image/s3,"s3://crabby-images/44238/4423801840804dd4f4539345affc79db26cda63c" alt=""
data:image/s3,"s3://crabby-images/b5711/b571180f3e8bbc74cb1ba0c35c4143aa7c1f519a" alt=""
data:image/s3,"s3://crabby-images/9f810/9f810523277757caf968356790b930f5cd4f0ac2" alt=""
the shader takes two scrolling normal maps and blends them together in a way that better preserves detail than just learping or adding them.
the reflection is code is just copied from unity's standard shader
data:image/s3,"s3://crabby-images/1b414/1b41446fd4f0aedcc3523ec5ce67476cefde311e" alt=""
data:image/s3,"s3://crabby-images/e0c2f/e0c2f92685d9988fd98a2e446cb9a4724816dba5" alt=""
data:image/s3,"s3://crabby-images/deb65/deb65960d91d55a8e403d3bd6c54a2cad92a3542" alt=""
we can get a texture with everything that has already been drawn to the screen using a grab pass: docs.unity3d.com/Manual/SL-Grab…
now we can sample from this texture using distorded uvs based on our normals
data:image/s3,"s3://crabby-images/39f62/39f62615f5099e2058b5f2627413ef3a241ba8f4" alt=""
data:image/s3,"s3://crabby-images/07cab/07cab90c87a99c5add36dd3ec7435510b9006559" alt=""
data:image/s3,"s3://crabby-images/e42ef/e42efd98c231a176f192cebce9fbe1be240100c8" alt=""
more detail in there, but basically these are sine waves that are pinched towards the peaks so you get some nice undulation on the surface
here i just have particles write the ripple height into the blue channel and then use that heightmap to deform the verts and normals of the water