紀錄和分享一下練習 Godot4 Shader 做的類 LED 面板效果
先附上 github 連結和效果:https://github.com/shizu0817/-godot-shader-LED-like-effect
data:image/s3,"s3://crabby-images/9a8bc/9a8bc0b34c76f8cdcc0318558f5d82b852c963c0" alt=""
data:image/s3,"s3://crabby-images/f2916/f2916f2140dc889a82f47e8d60d5f23b4163544b" alt=""
製作過程
使用這張圖測試並新增一個 Sprite2D 到場景裡面
data:image/s3,"s3://crabby-images/96998/96998d2b39c48545dc56f143621612e3d2af9930" alt=""
然後新增 Shader: 剛新增的 Sprite2D 裡 > CanvasItem > Material >
Material 內選擇 新增ShaderMaterial > Shader 選擇 新增Shader
data:image/s3,"s3://crabby-images/edd7f/edd7fbe11f3e5e5b32769a48144bfd0a4681e74e" alt=""
進入到 shader 編輯器後
首先為了要做出很多小 LED
我們先從繪製出一個圓形開始
data:image/s3,"s3://crabby-images/6c2de/6c2de108ab6ca9e3711c064fd6157b3a48d68e70" alt=""
data:image/s3,"s3://crabby-images/5b617/5b6172f5c251196eb730d7efa69ef644135aa385" alt=""
平滑一下邊緣、反轉黑白
data:image/s3,"s3://crabby-images/e771f/e771f0ef848492ac47b1be2a627418b8d6803ecf" alt=""
data:image/s3,"s3://crabby-images/dc481/dc48153a6f66b5e2a847d642d2f07ae95724bf86" alt=""
畫出一個圓形後
接著複製出這些圓形,製作出類似 LED 面板的樣子
參數 uv_scale 可以調整在水平跟垂直方向複製的個數
使用 fract ( UV * uv_scale ) 做出重複這個圓形的效果
data:image/s3,"s3://crabby-images/57197/57197d5a8779bddd4a1ef77d22b5eccd94857458" alt=""
data:image/s3,"s3://crabby-images/8c589/8c5890f37116058e367b59edfda53ed5e7148b67" alt=""
data:image/s3,"s3://crabby-images/89fc4/89fc4101071bf482809c1eb58e352024e7a40d15" alt=""
調整一下重複的數量
data:image/s3,"s3://crabby-images/53f10/53f10d4c305f5d98310fad746cebbbcfca42c456" alt=""
data:image/s3,"s3://crabby-images/15c08/15c08ca0878dae8a37f0c5168c4cba51e12b806d" alt=""
有了面板的樣子後
就要來在 shader 內讀取圖片 texture 讓圖片顯示在 LED 上了
我想要的是在白色圓形內顯示圖片顏色,圓形外面顯示黑色
所以我使用 mix() function 做內插來達到這個效果
data:image/s3,"s3://crabby-images/54e5d/54e5df72eb2f40a75dc566c350eb109f93e566f1" alt=""
data:image/s3,"s3://crabby-images/5a1c7/5a1c756ba98cf90144948db5f04b2183d53625a0" alt=""
data:image/s3,"s3://crabby-images/dba77/dba774c843fee1baa739afa09d4777102651c789" alt=""
這樣做了以後,可以發現有幾個問題
1. 圖片是透明的地方,經過 shader 處理後也會是透明的 (上圖能看到後面的 godot icon)
2. 每個 LED 內不是只顯示一個顏色
我對第 1. 點的處理方法是設定一個參數可以調整 LED 不發光時的顏色
所有輸出的 RGBA 值都一定要大於等於這個設定值
所以如果參數設定 alpha = 255 (1.0),就不會顯示透明的顏色了
data:image/s3,"s3://crabby-images/f0751/f07515941e56a80e815f764c4d4ed3a354376720" alt=""
data:image/s3,"s3://crabby-images/5e74c/5e74c46f17414058bd145aa97298d334bf1d2f21" alt=""
參數調整至 #323232, alpha = 255
在第 2. 點,如果要讓一個 LED 內都顯示同一個顏色
就要讓一個 LED 裡面每一個 pixel 採樣的 texture 顏色相同
也就是一個 LED 裡面每一個 pixel 用來採樣 texture 的 uv 值必須一樣
直接上圖解釋過程
data:image/s3,"s3://crabby-images/d3959/d39591ac521e68ed0146788d5650bb072a68ccb0" alt=""
data:image/s3,"s3://crabby-images/75563/7556377b0872534938163bcd143dc107529327db" alt=""
data:image/s3,"s3://crabby-images/f7cba/f7cbaedc21a117dd90151ee32bb6592b1c8c5957" alt=""
到這裡可以說是大功告成啦~~
利用這樣就可以做出其他很多的效果了
捲動的效果
data:image/s3,"s3://crabby-images/4534f/4534fd6fb55a27d6c3665392613e1fdf67d1f2ca" alt=""
可以編輯圖片留下一些空白的捲動空間
data:image/s3,"s3://crabby-images/695e0/695e008857259d33eb79f846bb149a8571464108" alt=""
要調整節點的 Repeat 屬性
data:image/s3,"s3://crabby-images/2c080/2c080e6833076faf3f3b236b1a81c70c361d5706" alt=""
在採樣 texture 的 x 方向加上時間,產生橫向捲動效果
data:image/s3,"s3://crabby-images/efe09/efe09c77e3d47e07988c9e3a390cfd2134775f9d" alt=""
Glow 輝光效果
注意:Godot4.1 無法使用,製作時是使用 Godot 4.2-dev5。(Godot 3.x 未測試)
設置:
1. 進入 Project Settings > Rendering > Viewport > HDR 2D 勾選開啟。(要重開 Godot)
data:image/s3,"s3://crabby-images/a0a44/a0a445cf1e10054cd4dd38c7645ec34caa93f3f0" alt=""
2. 在場景中加入 WorldEnvironment 節點後,設定如下
data:image/s3,"s3://crabby-images/5bde8/5bde842a7843f06374039246151eafe67b9e0a3b" alt=""
3. 我的作法是讓原本 LED 的 RGB 值,高於參數 glow_above 的時後,
讓超過的 RGB 值平滑的增加(要加超過 1.0)。
參數 glow_strength 可以調整增加的最大值。
data:image/s3,"s3://crabby-images/25f6f/25f6f8aa604f01a1355af602d40fa1419bd7c152" alt=""
data:image/s3,"s3://crabby-images/75f3e/75f3e7a2186854667e937579fcec029876f6bd34" alt=""
使用灰階材質圖做出一些特效
data:image/s3,"s3://crabby-images/3c215/3c215a4b6935a8ae71d372491f759a03dcc26dae" alt=""
data:image/s3,"s3://crabby-images/dcb4b/dcb4ba67c69093956df403daa116cca1a1501a65" alt=""
使用單張圖片
data:image/s3,"s3://crabby-images/f2916/f2916f2140dc889a82f47e8d60d5f23b4163544b" alt=""
使用 spritesheet ( 較複雜 )
總結 & 參考資料
這個類 LED 的 shader 是看到 https://www.artstation.com/artwork/2xyxzK 後
想說練習做做看類似的效果,以上就是我練習過程中的想法
如果有興趣或任何問題,歡迎留言一起討論~~
參考資料:
- 靈感來源-https://www.artstation.com/artwork/2xyxzK
- 素材來源-https://www.kenney.nl/ & https://www.kenney.nl/assets/alien-ufo-pack
- GLOW-https://github.com/godotengine/godot/pull/80215
- Godot 4.2 dev5-https://github.com/godotengine/godot-builds/releases/tag/4.2-dev5
我的連結:
- twitter:https://twitter.com/Czu000
- itch.io:https://czu7985.itch.io/