Version: 5.3 (switch to 5.4b)
言語English
  • C#
  • JS

スクリプト言語

好きな言語を選択してください。選択した言語でスクリプトコードが表示されます。

MonoBehaviour.OnAudioFilterRead(float[], int)

フィードバック

ありがとうございます

この度はドキュメントの品質向上のためにご意見・ご要望をお寄せいただき、誠にありがとうございます。頂いた内容をドキュメントチームで確認し、必要に応じて修正を致します。

閉じる

送信に失敗しました

なんらかのエラーが発生したため送信が出来ませんでした。しばらく経ってから<a>もう一度送信</a>してください。ドキュメントの品質向上のために時間を割いて頂き誠にありがとうございます。

閉じる

キャンセル

マニュアルに切り替える

パラメーター

data オーディオデータを持つ float 配列
channels デリゲートに渡されたオーディオデータのチャネルの数を格納する int

説明

OnAudioFilterRead が実装されている場合、Unity は DSP チェーンにカスタムフィルターを挿入します。

フィルターはインスペクターに表示されている MonoBehaviour スクリプトと同じ順番で挿入されます。

OnAudioFilterRead は毎回呼ばれているオーディオのチャンクをフィルターに通すルートです。(これはサンプルレートやプラットフォームに応じて毎回 ~20ms で頻繁に発生します。) オーディオデータは-1.0f から 1.0f までの float 値の配列で、チェーンのフィルター前のオーディオ、または AudioSourceAudioClip を含みます。これがチェーンの最初のフィルターでオーディオソースがアタッチされていない場合、このフィルターはフィルタリングしたことになります。そうすれば手続き的にオーディオの生成を行い、オーディオクリップのようにフィルターを使用することができます。

OnAudioFilterRead が実装されている場合、VU メーターはサンプルレベルを出力を表示するためにインスペクターに表示されます。フィルターの処理時間も測定され、使用済みのミリ秒は次の VU メーターに表示されます。(ミキサーがオーディオデータを開始したときに、フィルターが多くの時間を費やしている場合、赤色に変わります) また、OnAudioFilterRead はメインスレッドとは異なるスレッド(すなわちオーディオスレッド)上で呼び出されるため、大多数の Unity の関数を呼び出しは許可されていないことに注意してください(警告が表示されます)。

See Also: Audio Filters.

	// This custom filter controls the gain by filtering the samples by multiplying each sample with a <i>gain</i> parameter.  

public var gain : float;

function OnAudioFilterRead(var data:float[], var channels:int) { for (var i = 0; i < data.Length; ++i) data[i] = data[i] * gain; }