静的バッチ処理は、動かない(静的な)オブジェクトをひとまとめの大きなメッシュと結合してレンダリングする。 動的バッチ処理は、今のところよく分からない…小さいメッシュ用に頂点をひとまとめにして描画するらしい 欠点もある。 静的はメモリとストレージを消費し、 動的はCPUを消費する。
スプライトパッキングモードは、デフォルトがディセーブルで、Enabled for builds(パッキングはビルドの時に有効、プレイモードでは無効)とAlways Enabled(ビルドの時もプレイモードの時もどちらもパッキングする)が選択できる。
重たい処理としては、スキンドメッシュレンダー、ポストプロセッシング、アルファブレンディング、高解像度があります。本当に必要かどうかを検討して不要なら影やカメラ制御のように、パフォーマンスを得るために、ゲームシーンからカットしたり、最適化しても問題ないかを検討するのが良さそうです。
ゲームの軽量化につながる為の処置として、簡単なものは、影の廃止、ポストプロセスの廃止、マテリアルの統合、テクスチャアトラスの使用、メッシュの結合、テクスチャ圧縮形式の変更、サイズを減らす等がある。品質は下がるがFPSは良くなると思われるのでバランスをみて調整したい。
マテリアルをオブジェクトあたりで減らす事がパフォーマンス改善につながるのは、SetPassCallの呼び出し回数の削減に繋がっている為だと思われる。有料アセットのメッシュベイカーなどを利用すると、この辺りの仕組みをうまく最適化するので、ドローコール処理が軽くなり、軽量化につながる
バッチの回数はStatsの画面から確認する事ができ、Batchesがバッチ処理の回数を表して各バッチごとにSetPass Call→DrawCallの順に呼ばれレンダリング処理を行う。1バッチに1回のドローコール処理があるがマテリアルの指示がない場合はSetPassCallが省略
ゲームのパフォーマンスを向上させるにはドローコールを減らす必要があります。ドローコールはオブジェクトやテクスチャをGPUがレンダリングする時に呼ばれます。ドローコールはCPUからAPIを使って呼ばれるので、ドローコールが多くなればなるほどゲームのパフォーマンスが落ちます。
ドローコールはUnityでは一回の処理としてまとめる機能がある。ドローコールバッチング機能によってドローコール負荷をひとまとめにして、ゲームのパフォーマンスが出るようにしている。バッチ処理には二種類あって、動的バッチ処理と静的バッチ処理がある。
OpenGLやDirectXはグラフィックスAPIというソフトウェアに描画命令を行うアプリケーション・プログラミング・インタフェースの名称で、描画命令はCPU→グラフィックスAPIに指示が行われている。ドローコールが重たい時=CPUに負荷がかかる。ではドローコール表示はどうするか