はじめに
ADXアンバサダーとして記事を書いておりますSigと申します。
この記事ではアンリアルエンジン5とサウンドミドルウェア「ADX for UE」を連携させた際、新機能である「ADX Atom Insights」を使い、ゲーム内サウンドのモニタリング・分析を行ってみます。
ADX Atom Insightsは「ADX for UE」を使用して再生するサウンドを、ランタイムでモニタリングできる機能です。
音声の再生状態などを視覚的にチェックできるため、サウンドデザインやデバッグに使用できます。
前提
UE5.5+「ADX LE UE SDK(2.04.00)」を使用します(他バージョンにおいても、基本的に実装方法は同じです)。
基本的にブループリントのみでの実装を想定しています。
ADXはインディー向けの「LE版」であれば、無料で使用できます。
https://game.criware.jp/products/adx-le/
なお、ADX2からADXへ名称が変更になりましたが、ツール構成は変更ありません(2がないから古いほう、というわけではありません)。
ADX for UEの導入や基本的な使い方は以下の記事にあります。必要に応じて参照してください。
ADX for UEの導入で、一歩上のサウンド表現を(導入編)
ADX for UEの導入で、一歩上のサウンド表現を(実践編)
ADX Atom Insightsを使用する
プラグインを有効にし、ADX Atom Insightsを使用する
ADX Atom Insightsは別プラグインとして提供されているので、プラグイン管理から有効にする必要があります。
「Edit」→「Plugins」からプラグインの管理を開きます。
「CriWare」タブの「CriWare ADX AtomInsights」にチェックを入れます。
現バージョンでは、ここで実験段階の機能である旨のダイアログが出ます。Yesを選択します。
エディタの再起動を促すボタンが出るので、押して再起動します。
再起動後、「Tools」→「ADX Atom Insights」の項目が追加されています。
選択するとADX Atom Insightsが起動します。
デバッグ時は、別ディスプレイなどに置いておくと良いでしょう。
この状態でゲームを再生すると、Atom Cueなどで再生されたサウンドが記録され、一覧や再生状態が閲覧可能になります。
サンプルプロジェクトでADX Atom Insightsを試すには
手っ取り早くこの機能を試す場合、ダウンロードしたSDKに含まれているサンプルプロジェクトを使用するのが良いでしょう。
ADX Atom InsightsはUE5.5以上でしか使用できないため、サンプルプロジェクトの設定を変更する必要があります。
サンプルプロジェクトはSDKの「\cri\UnrealEngine\Sample\CriWareShowRoom」にあります。
「CriWareShowRoom.uproject」を右クリックし、「Switch Unreal Engine version」を選択します。
バージョンが5.5未満の場合、5.5以上に変更してOKを押します。
もしここが5.5以上だった場合、変更の必要はありません。
処理が走り、プロジェクトのバージョンが変更されます。通常通りプロジェクトを開き、上記の手順でプラグインを有効にします。
サンプルプロジェクトで、ADX Atom Insightsが使用できるようになりました。
ADX Atom Insightsでのモニター
ADX Atom Insightsではサウンド方面で起きたこと、音量やキューの状態などを監視できます。
ログや波形、出力先を分けたモニタリングなども可能です。
再生しているはずなのに聞こえないキューや、明らかに大きすぎるサウンドの距離減衰状態を確かめたい、という際などに活躍しそうです。
捕捉: バックグラウンドでfpsが落ちるのを防ぐ
ADX Atom Insightsを使ったデバッグ中、別ウィンドウで操作や記録などの作業を行いたい場合も多々あるかと思います。
しかしウィンドウのアクティブ状態が解除された際(バックグラウンド)、UE5のデフォルトでは描画を省いてFPSを減らし、負荷を軽減する設定になっています。この状態ではAmp(Peak)の検出が正常にされず、グラフにも異常が出てしまいます。
ウィンドウのアクティブ状態を解除してもスムーズな描画を続けるよう、エディタの設定を変更することで解決します。「Edit」→「Editor Preferences」からエディタ設定を開きます。
「Performance」タブを開き、「Use less CPU when in Background」のチェックを外します。
これだけで完了です。バックグラウンドでも変わらず動作を続けるため、グラフの動きも正常になります。
捕捉: バックグラウンドのミュートを解除する
デフォルトではウィンドウが非アクティブの場合(バックグラウンド)、サウンドがミュートされてしまいます。継続してデバッグをしている場合、ここはサウンドを鳴らし続けて欲しいものです。これはエンジン設定を変更することで解決できます。
「(プロジェクトフォルダ)\Config」にある「DefaultEngine.ini」を編集します。
該当のファイルをテキストエディタなどで開き、次の設定を追記します。
[Audio]
UnfocusedVolumeMultiplier=1.0
プロジェクトを開き直します。
これでバックグラウンドでのミュートが解除されます。もとに戻す場合は該当の部分を消すか、
[Audio]
UnfocusedVolumeMultiplier=0.0
と記述すればOKです。