-
Notifications
You must be signed in to change notification settings - Fork 17
UnToon 2018 to 2019 migration
Unity2018 の UnlitWF/UnToon では、各種機能のON/OFFに変数+if分岐を使用していました。
それに対し Unity2019 では shader_feature_local
が導入されたため、各種機能のON/OFFにはローカルキーワードを使用するよう変更しています。
変換前のマテリアルを unity2019 で確認してもマテリアルエラーにはなりませんが、Metallic, ToonShade, RimLight などの各種機能はOFFになっているように見えます。これは各機能をONにするためのキーワードがマテリアルにはまだ設定されていないためです。
変換手順は、マテリアルをひとつひとつ変換する案Aと、一括で変換する案Bを用意しました。 すでに変換済みのマテリアルを再度変換しても問題ないようにしています。UnlitWF の各マテリアルを1回以上変換し、マテリアルにキーワードを設定してください。
キーワードの設定は、UnlitWF の拡張インスペクタが自動で行います。マテリアルを Inspector で開くと即座にキーワードが設定されて各機能のON/OFFが整理されます。
Project からマテリアルを複数選択し、右クリック → UnlitWF Material Tools
→ Migration material
を使用します。
各種機能のON/OFFにローカルキーワードを使用するようになったため、VRCSDK がマテリアルの警告を出してくるようになりました。
ただし UnlitWF で使用しているものは全てローカルキーワードであり、グローバルなキーワード空間を汚さないため、この警告は無視して構いません。
VRCSDK の Shader Keyword Utility を使用するとマテリアルからキーワードが消去されるため、各種機能がOFFに変わったように見えます。 この場合であっても上記の手順でマテリアルのキーワードをリフレッシュし、各種機能を復活させることができます。
マテリアルから不要なキーワードを削除するツールも用意しています。マテリアルを右クリックして UnlitWF Material Tools
→ Migration material
を選択します。
「ShaderKeywordsも一緒にクリアする」にチェックを入れて CleanUp ボタンを押すと、不要なキーワードがマテリアルから削除されます。
機能のON/OFFにキーワードを使用するようになったため、Unity2018 までは使用していない処理もビルドに含まれていたところ、Unity2019 以降は使用していない処理はビルドに含まれないよう Unity の側で最適化が行われます。 そのかわり多数のシェーダバリアントを作成するようになったため、ビルド後のサイズは 2018 よりも 2019 のほうが平均すると大きくなります。
これをさらに削減するため、UnlitWF では ScriptableShaderStripping を用いて、ビルド時に余分なシェーダバリアントを削除する仕組みを導入しています。
この仕組みは初期状態では有効ですが、設定から無効にすることも可能で、設定ファイルが UnlitWF_ShaderSuite/Editor/WFEditorSettings.asset
にあります。
-
Enable Stripping
- チェックすると UnlitWF 独自のシェーダバリアント削減が有効になります。
- チェックを外すと無効になりビルドサイズが増えます。なおチェックが外れた状態でも Unity 側での最適化は有効です。
-
Strip Fallback
- チェックすると Fallback シェーダをビルドから除外します。PC版において通常は Fallback が使われることがないため見た目には変化がありません。
- Android(Quest) 向けワールド作成、あるいは他デバイス向けに UnlitWF を使用する場合など、Fallback が必要な場合はチェックを外してください。
-
Strip Meta Pass
- チェックするとライトベイクに使う META パスをビルドから除外します。ライトベイクは通常はエディタ上で行われるためビルドから除外されても問題ありません。
- RealtimeGI を使う場合など、ランタイムでライトマップを作成するために META パスが必要な場合は、チェックを外してください。
-
Always Include Shaders
- ShaderVariantCollection で、削減の対象外にするシェーダ・パスを指定することができます。
-
Always Include Materials
- マテリアルを指定して、削減の対象外にするシェーダを指定することができます。