簡介
在一連串效能優化介紹後,可以在 Unity 找到很多方法,而今天要來講一個透過我們常用的製作材質工具來建立體積非常小的材質包,就是 Substance 的 .Sbsar 格式的材質球。
前提
在過往我們的製作程序是進入 Substance Painter 繪製好材質後,匯出數張材質的貼圖,通常幾張貼圖所佔的空間就是好幾十MB,更大的物件可能大到幾百MB,一併整合在場景中,累積起來的記憶體Loading可說是非常吃重,我們來看看一般的貼圖與材質球的大小。
data:image/s3,"s3://crabby-images/2dd49/2dd49432a284217c7c26d86421b9351be88ee88a" alt=""
製作.SBSAR檔案
我們在 Unity 中要使用 .Sbsar 檔案的話要先至 Asset Store 下載 Substance in Unity Plugin,下載好請 Import。
data:image/s3,"s3://crabby-images/16937/169378574035a30f115aeb26168d5b2a55c7dfe6" alt=""
我們先轉台至 Substance Designer 軟體將先前透過 Painter 匯出的 Texture 進入 Designer 匯出 .Sbsar 檔案。
先前已經學會在 Painter 設定匯出 Unity HDRP 的設定,但我們現在是要丟到 Designer 產出 .Sbsar 檔案,所以透過 Painter 匯出6個格式的檔案如下圖。
data:image/s3,"s3://crabby-images/61bbc/61bbc758873c45adcac03c0def4ad238f995ebed" alt=""
接著開啟 Designer 新增一個 Graph 檔案,並選擇 PBR Template。
data:image/s3,"s3://crabby-images/9b980/9b9800d27127b34f1e14ea46e3f7e91eb76fe8b3" alt=""
把剛剛從 Painter 匯出的圖檔拉到畫布中 ,並將相對應的圖檔連結至正確的Channel中。並可以看3D View中的效果再來做一些微調。
data:image/s3,"s3://crabby-images/f8424/f8424f6ff0446e066f23ed2b179c744ff5c426ec" alt=""
最後匯出 .Sbsar 格式,依照下圖的順序點選並匯出即可,製作 .Sbsar 步驟大概就到這邊,其實也可以使用 Substance Alchemist (煉金術師)軟體匯出也可以。
data:image/s3,"s3://crabby-images/a64b9/a64b903e040be09ca37d2fef57a315713955dbed" alt=""
將.SBSAR匯入Unity
data:image/s3,"s3://crabby-images/0eda5/0eda503d019ce4eb9f531ad37ede046f1bbd6196" alt=""
將剛剛製作好的 .Sbsar 檔案匯入 Unity 時 (要先安裝好Substance in Unity Plugin)就可以看到如上圖的樣式。
data:image/s3,"s3://crabby-images/8f620/8f620c467fd8d7b4ffafcf8b13aaa9bff8b857ed" alt=""
而在將材質球丟到模型前我們可以看看 .Sbsar 檔案大小,34.2 < 65 MB,與舊有的基本製作流程小了快兩倍的資源,而且圖片大小都是2048*2048。
data:image/s3,"s3://crabby-images/36338/363387d151f3cfbb86c90d66d34948091bfcdbfc" alt=""
跟以往的 Texture Setting 有點類似,但 .Sbsar 檔案是整合了所有 Texture 可以一併作調整。接著我們把包在 .Sbsar 中的 Material 拖曳至模型中,就完成了。
當然 .Sbsar 的材質球依樣可以在 Unity 中做調整,此外掛是使用了HDRP/LitTessllation Unity Shader,所以不需要將 .Sbsar 轉換成 HDRP。
data:image/s3,"s3://crabby-images/01474/01474e2035bfdce3bfa81528e88b3a9bbf09e718" alt=""
下圖為兩個模型運用 Basic Texture + Material 花費 65MB (右邊物件) VS .Sbsar Substance Material 花費 34.2MB(左邊物件)。
data:image/s3,"s3://crabby-images/aa59b/aa59bb8887009f09d70fe8efb7d3eca585f8fcff" alt=""
小結
data:image/s3,"s3://crabby-images/02246/022467019023e1822353c6b84fa4aac65b71a986" alt=""
當然使用 Unity 內建的 Compression 或是調整 Max Size 會降低大小,但是畫質也會跟著打折,雖然使用本篇介紹的流程會多一個步驟,但能讓整個場景跑得動、跑的順、跑得漂亮才是最終目標,在未來遇到多物件與大場景的專案時,可以嘗試使用這方法,順便做一個效能實測。