data:image/s3,"s3://crabby-images/570d3/570d30fe777fa716ecf110a2225da1358f7a3a03" alt=""
教學
展示一下怎麼使用 GPUParticle + Shader 做到下面這兩個效果
data:image/s3,"s3://crabby-images/1d76c/1d76cbdd6bf33d2a9b27b932f1ef183fafbc47ad" alt=""
data:image/s3,"s3://crabby-images/929b4/929b4ceb03f540dc849cc5bd4eb56663d69cf8a5" alt=""
從上到下消失
先在 Sprite2D 上套用一個 Shader
讓 Sprite 可以由上往下消失
data:image/s3,"s3://crabby-images/168eb/168eb21435062a5a1c2697f488583b181d206f4e" alt=""
當 UV.y 小於參數 dissolve_below 就是透明的 vec4(0.0)
反之就是 原本 texture 的顏色 tex_color
data:image/s3,"s3://crabby-images/78783/78783680e371a17b51625bf6801ddf2faca7c824" alt=""
調整 dissolve_below 的變化
建立一個新的 Node2D 場景
然後新增一個 GPUParticles2D 子節點
data:image/s3,"s3://crabby-images/71f9f/71f9f6dce1d3c471dd830f3fa06bda00233709a7" alt=""
GPUParticles2D 節點裡新增 ParticleProcessMaterial
data:image/s3,"s3://crabby-images/7eb93/7eb93d24fc4952f1fe5b45fe9e3dcb2266d8f333" alt=""
在 ParticleProcessMaterial 裡面調整粒子效果
可以調整顏色、大小等等
然後把 Gravity 重力調成 0
重點是要將 Emission Shape 改成 Box
Box Extents的 xy 改成 Sprite 高寬的一半
data:image/s3,"s3://crabby-images/27e00/27e00b95fe4c7e744e2a33c0e81ca649bf7e42c4" alt=""
調整完後點選 ProcessMaterial 最右側的勾勾
打開選單選擇 轉換為 ShaderMaterial
data:image/s3,"s3://crabby-images/f5fe4/f5fe43cf808e95a83f0c5d63222af8b366e98c89" alt=""
剛剛調整的粒子參數
會自動轉換成 particles shader code
(但是 texture 不會保留,比如 GradientTexure 或是 CurveTexture
只會生成對應的 shader 程式碼 和 uniform 參數
所以要再重新設定)
下圖有調整粒子數量、顏色、大小等等
只要畫面是在一個方形內生成粒子
粒子固定不動就可以了
data:image/s3,"s3://crabby-images/4104f/4104f96967dcae2482d001cd3f37ac8ebf35141b" alt=""
接著我們要開始控制粒子生成的位置
先把 GPUParticles2D > Drawing > Local Coords 設成開啟
讓粒子的座標位置是相對於父節點的位置
data:image/s3,"s3://crabby-images/d017d/d017df9bffe7ba8a5eae501a13fcf2bafe03fa2f" alt=""
打開剛轉換的 particles shader
在 uniform 參數的最後加上 3 個參數
sprite:限制粒子只能生成在 sprite 不是透明的位置
down_border、top_border:限制粒子只能生成在 down_border ~ top_border 的範圍內
data:image/s3,"s3://crabby-images/51a00/51a00a40699508d05e88f3c7af941c92bbb1ee36" alt=""
找到 shader 裡的 start() function [註解1]
在 function 最後加上這段 code
data:image/s3,"s3://crabby-images/02539/025392491efcf30b7ca622c17fbf1e5a4691285a" alt=""
這裡做的事情是把粒子的位置
轉換成 sprite texure 的 uv
然後用 uv 計算出遮罩
把起始位置在遮罩外的粒子的 ACTIVE 屬性設為 false
這個粒子就不會產生了
粒子的位置資訊是儲存在 TRANSFORM [ 3 ] 裡
所以把位置除上 sprite 大小 + 0.5 就是 uv
然後再以 sprite 的透明度 和 兩個參數 top_border 和 down_border 所夾的區間當成遮罩
用 if 判斷把不在範圍內的粒子 ACTIVE 設成 false 就好
設定一下剛剛 3 個參數
看一下效果
data:image/s3,"s3://crabby-images/a8149/a814938e20bebf6394e6dd9ce032f36cf40f4920" alt=""
調整 down_border 和 top_border 的變化
到這邊基本上就完成了
現在要加入一點變黑加深的效果
重複利用一下剛剛的 particle shader 來做
先將剛才的 particle shader 存檔
data:image/s3,"s3://crabby-images/bc0c0/bc0c0f85a58d8ce546644dc5e18082f7a10e5dc7" alt=""
在同一個場景裡加入一個新的 GPUParticle2D
新增 ShaderMaterial 載入剛剛存檔的 particles shader
data:image/s3,"s3://crabby-images/3c46a/3c46a14a8d885794b6a326459969cdc319c6e3de" alt=""
data:image/s3,"s3://crabby-images/76d6f/76d6f75b9a9d8eb77d0cab879f10308b9d4c654c" alt=""
調整 texture 如下圖
data:image/s3,"s3://crabby-images/09511/09511e9d73f6665529155e3717083029a8271a00" alt=""
然後在 CanvasItem 裡新增 CanvasItemMaterial
Blend Mode 改成 Subtract
data:image/s3,"s3://crabby-images/2bc3d/2bc3df1d1a3a5b4ed62bfc910bb053d343d96218" alt=""
就可以得到類似這個的結果
data:image/s3,"s3://crabby-images/ceab7/ceab7dcf2eeb06de5c8a13f1ec678223d8711887" alt=""
最後使用 AnimationPlayer 去調整這些 shader 的參數
data:image/s3,"s3://crabby-images/1d76c/1d76cbdd6bf33d2a9b27b932f1ef183fafbc47ad" alt=""
使用 NoiseTexture 消失
在這裡主要講一下跟前面例子不同的部分
套用在 sprite 的 shader 如下
data:image/s3,"s3://crabby-images/7aff3/7aff3ce68fb2b9d2b7bf775306fd9624595c797b" alt=""
跟前面的差異是使用 noise texture 判斷哪個部份是要消失的
設定 shader 的 noise 參數
data:image/s3,"s3://crabby-images/26db8/26db8454d98eb9a83c7279143fd85c8e61b91ed0" alt=""
data:image/s3,"s3://crabby-images/7fce2/7fce24d6c1e579694d661d899653d42acec59d42" alt=""
FastNoiseLite 的參數可以自由調整
設定好 noise 後看一下效果
data:image/s3,"s3://crabby-images/ea312/ea3123457cf202680dbbb2bea77004afb58e32c7" alt=""
調整 dissolve_below 的變化
直接跳到 particles shader 的部分
data:image/s3,"s3://crabby-images/82ce5/82ce58549adaa78e9e3b7523a041793da80d7aaf" alt=""
多一個 noise 參數
data:image/s3,"s3://crabby-images/e4b6a/e4b6ad2e222c5e733454aa18d74299bf00526481" alt=""
以 noise 值計算遮罩範圍
noise 參數記得要跟 sprite 套用一樣的 noise texture 才可以
看一下效果
data:image/s3,"s3://crabby-images/11ec5/11ec5664025408ad7dc0dd304ce6f6969c39c59c" alt=""
加上一樣的變黑效果
一樣使用 AnimationPlayer 製作動畫
data:image/s3,"s3://crabby-images/929b4/929b4ceb03f540dc849cc5bd4eb56663d69cf8a5" alt=""
註解 1:particle shader 裡面有 start() 和 process() 兩個 function
一個是在粒子生成的時候執行,另一個是生成後會重複執行
類似 Node 裡的 _ready() 和 _process()
目前在學習 shader 製作不同的效果
順便分享一些做出的效果並製作教學
歡迎給予意見和指教 OAO 掰掰~