In this article, I introduce how to make waves breaking on the shore by Shaderforge in Unity.
data:image/s3,"s3://crabby-images/73762/7376201336b781d97d8fddcd9d8d1e141411c95c" alt="Wave01_fin - STYLY 波のシェーダー"
The Shader to express waves
It represents waves breaking on the shore and retreating from as shown above. We make a simple one that you can use just by assigning it to a Plane.
Samples
You can taste a sample space in STYLY GALLERY.
You can download the Unity project shown in this article. Wave_Sample
As this project data doesn’t include some plug-in required, install them by yourself. Playmaker SteamVR Plugin
Add a new shader by Shaderforge
There are just two planes for the waves and for the beach. Open Shaderforge and create a new shader by New Shader > Lit(PBR).
data:image/s3,"s3://crabby-images/6d360/6d360ad52c47da8436ca51793c0b1e35b2fb20ef" alt="Wave01_01 - STYLY"
Create a new shader by Shaderforge.
As we adjust transparency, change Blend Mode to “Alpha Blended “.
data:image/s3,"s3://crabby-images/9dc90/9dc90207febc2be95b3cc3f030ce32b82e340b72" alt="Wave01_02 - STYLY ブレンドモードの設定"
The setting for Blend Mode
Check the box for OpenGL ES3.0 to use in STYLY.
data:image/s3,"s3://crabby-images/490b1/490b12dc45dd363ce4e758ce5ed2eb7f046a9dd4" alt="Wave01_03 - STYLY OpenGL ES 3.0にチェック"
Check the box for OpenGL ES 3.0
Change shape by Heightmap
We actually change the shape of a polygon mesh by applying a grayscale texture on it. You can introduce a realistic expression by changing the shape of an object.
data:image/s3,"s3://crabby-images/5519a/5519aa828fe47b11fbb38fd8f600791956187357" alt="Wave01_04 - STYLY 波のHeightmap"
Heightmap for the waves
This texture is made of a cloud-pattern in Photoshop. We use it in Shaderforge. Make a Texure2D node by dragging the texture to the Shader Forge window.
data:image/s3,"s3://crabby-images/4f471/4f4710c3381a05159809235bbd28992dfbc03948" alt="Wave01_05 - STYLY テクスチャを使用する"
Use a texture.
Make an animation of waves by scrolling UV.
data:image/s3,"s3://crabby-images/e2d2e/e2d2e861ef24e17be411903064f49a5dd7d2deb5" alt="Wave01_06 - STYLY PannerとUV Coordをつなぐ"
Connect Panner and UV Coord.
Add a Panner node and a UV Coord node, and then, connect them to the texture. In this state, it just scrolls in one direction. So we add a back-and-forth motion.
data:image/s3,"s3://crabby-images/7eaef/7eaef503d39207992117a80d487801d3b1d320ba" alt="Wave01_07 - STYLY 時間で制御する"
Control it by “Time”
You can make it move back and forth by “Sin”. Set “Time” for the speed of the motion and “Remap” for the range. Acquire the direction of the vertices’ motion by Normal Direction, and combine it with the motion of the texture by a Multiply node. You can now change the shape of the object by connecting it to VertexOffset.
data:image/s3,"s3://crabby-images/ac71f/ac71f8f3b25f41c8e518124044ebf4da23f99ae3" alt="Wave01_08 - STYLY Vertex Offsetで頂点移動"
Moving the vertices by Vertex Offset
In the current state, the motion hasn’t been applied to the scene yet. Assign the material with the new shader to the Plane, and specify the texture to apply in the Inspector window.
data:image/s3,"s3://crabby-images/61360/61360f0bd1762d396b38567d9e6dda36759f399f" alt="Wave01_09 - STYLY テクスチャを指定する"
Specify the texture.
It adds some variations to the shape of the Plane. You can see the vertices have been shifted in their normal direction by the greyscale texture.
Adjust the height of waves
Make the motion more dynamic by adding up-and-down motion to the entire wave. Add a slider called “Waveheight” to adjust the height.
data:image/s3,"s3://crabby-images/b1202/b1202a8e43fa73078db2dc1795746b253dfedd0c" alt="Wave01_10 - STYLY 波の高さのスライダー"
The slider to adjust the height of the wave.
In addition, add a slider called “Wavewidth” to adjust the width of the waves surging.
data:image/s3,"s3://crabby-images/097c6/097c6fdbc918266758ff49ca9db49648ec2681dd" alt="Wave01_11 - STYLY Wavewidthの調整"
Adjust “Wavewidth”
Specify the direction of the entire wave by a Value called “Wavedirection”.
data:image/s3,"s3://crabby-images/4c5be/4c5be4ab89d9f1bac90c07f4459d0d0956b5fc47" alt="Wave01_12 - STYLY Wavedirectionの調整"
Adjust “Wavedirection”
I set the direction to Z-axis only.
Add Heightmap
Next, add a Heightmap.
data:image/s3,"s3://crabby-images/3c34f/3c34f869407da375a0d814db42ea8e0e49439769" alt="Wave01_13 - STYLY Heightmapの追加"
Add a Heightmap.
As the white part expresses a rise, scroll it to represent the waves surging periodically.
data:image/s3,"s3://crabby-images/8386b/8386bfd9112039818fea3c9fae415926cd83fb40" alt="Wave01_14 - STYLY UVをスクロールする"
Scroll UV
Impose “Add” between “Panner” and “UV Coord”, and connect “Vector2” to it. Although it moves UV a little, it helps to synchronize it with the entire motion of waves. Put it and the cloud-pattern texture together by “Add”, and connect it to Normal Dir.
data:image/s3,"s3://crabby-images/f8ab3/f8ab31e4b002bb1c0f9b4d8ff665d4c15b87476b" alt="Wave01_15 - STYLY Addで追加する"
Add it by “Add” node
Once you specify the texture, it will be applied to the Material.
data:image/s3,"s3://crabby-images/ff162/ff162fd9017e93ca58f0017b51617bbc667e2766" alt="Wave01_16 - STYLY テクスチャを指定"
Specify the texture.
Now, you have implemented the motion by the gradation texture.
Add Normalmap
Add a Normalmap for finer details. It’s so easy to fine-tune the detail by Normalmap.
data:image/s3,"s3://crabby-images/78c44/78c44c9ddce9a6796c455a9816dec339e2f093ed" alt="Wave01_17 - STYLY 波のNormalmap"
Normalmap for waves
I made this texture by converting a cloud-pattern image into the normal-vector map in Photoshop. Add a motion to Normalmap by scrolling UV as we did earlier.
data:image/s3,"s3://crabby-images/763e1/763e12c230c0477383dd3162901ec6aa9cb99a44" alt="Wave01_18 - STYLY スクロールの設定"
The setting to scroll UV
You can add the Normalmap effect to the surface by assigning the texture in the Inspector window.
data:image/s3,"s3://crabby-images/4fcc4/4fcc432ee6bb2afb9edc0596c741665256442b66" alt="Wave01_19 - STYLY Normalにつなぐ"
Connect it to Normal.
It looks like the sea now.
Colour the sea
Blend brighter colour and lighter colour to make the colour more realistic for the sea.
data:image/s3,"s3://crabby-images/f007d/f007d5953359807b40d51e99aab01f9b1bd51272" alt="Wave01_20 - STYLY 海の色の設定"
The setting for the colour of the sea
Make the view responsive to the direction of the camera by adding Fresnel. Use the Hightmap with gradation as colour. Overlay the white part as it is to express a splashing wave.
data:image/s3,"s3://crabby-images/8c47d/8c47da04c5cc2f73a75937be5cc0b8a4ad5fa4c2" alt="Wave01_21 - STYLY 白く見える部分をブレンド"
Overlay the white part.
In this example, I imposed a Blend node and connected to “Screen” to overlay.
Use Alphamap
The tip of the waves has been left square. So now make it more wave-like shape. Make the effect by overlaying the wave-shaped texture with transparency.
data:image/s3,"s3://crabby-images/7668a/7668a1ea9692e747ccad26cd1364eb17fe8775b3" alt="Wave01_22 - STYLY 波の形のアルファマップ"
Alpha map with wave-shaped boundary
Set it to make this white part only visible. Combine the texture and the Value, and connect it to Opacity. You can adjust the transparency by the Value.
data:image/s3,"s3://crabby-images/96429/96429c81185df6a3fe91b9427fd6790b6281b073" alt="Wave01_23 - STYLY Opacityへつなぐ"
Connect to Opacity.
Switch off “Cast Shadow” as you don’t need the shadow of the Plane. It completes the shader for waves.
data:image/s3,"s3://crabby-images/73762/7376201336b781d97d8fddcd9d8d1e141411c95c" alt="Wave01_fin - STYLY 波のシェーダー"
The shader for waves
In this article, I introduced how to make a shader for waves by Shaderforge in Unity. You can make various effects by changing the shape of objects with Vertex offset controlled by a texture. You could save your time as it could substitute for some modelling works. How to upload an Asset from Unity to STYLY: Read this article