From 33058f2b292b3a581333bdfb21b8f671898c5060 Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Tue, 8 Dec 2020 14:40:17 -0500 Subject: initial commit --- files/ja/web/api/analysernode/index.html | 226 +++++++++++++++++++++++++++++++ 1 file changed, 226 insertions(+) create mode 100644 files/ja/web/api/analysernode/index.html (limited to 'files/ja/web/api/analysernode') diff --git a/files/ja/web/api/analysernode/index.html b/files/ja/web/api/analysernode/index.html new file mode 100644 index 0000000000..5f9d9a00e9 --- /dev/null +++ b/files/ja/web/api/analysernode/index.html @@ -0,0 +1,226 @@ +--- +title: AnalyserNode +slug: Web/API/AnalyserNode +translation_of: Web/API/AnalyserNode +--- +

{{APIRef("Web Audio API")}}

+ +

AnalyserNodeインタフェースはリアルタイム時間領域/周波数領域分析情報を表現します。{{domxref("AudioNode")}}は、入力から出力の流れにおいてaudio streamそのものは変えず、データ加工や音声の可視化をすることができます。

+ +

1つのAnalyzerNodeは必ず1つの入力と出力を持ちます。出力先がなくてもAnalyzerNodeは問題ありません。

+ +

Without modifying the audio stream, the node allows to get the frequency and time-domain data associated to it, using a FFT.

+ + + + + + + + + + + + + + + + + + + + + + + + +
Number of inputs1
Number of outputs1 (but may be left unconnected)
Channel count mode"explicit"
Channel count1
Channel interpretation"speakers"
+ +

Inheritance

+ +

このインタフェースは以下のインタフェースと継承関係にあります。:

+ +

{{InheritanceDiagram}}

+ +

Properties

+ +

 以下は、{{domxref("AudioNode")}}からプロパティを継承する.

+ +
+
{{domxref("AnalyserNode.fftSize")}}
+
+

符号なしのlong型の値でFFT(高速フーリエ変換)において周波数領域を決定するために使われているサイズを表している。

+
+
{{domxref("AnalyserNode.frequencyBinCount")}} {{readonlyInline}}
+
符号なしのlong型でFFT(高速フーリエ変換)のサイズの半分の値。一般的に音声再生時の可視化に用いられる。
+
{{domxref("AnalyserNode.minDecibels")}}
+
+

unsigned byte型値へ変換するFFT分析データのスケーリング時の最小のパワー値を表すdouble型の値である。一般的に、この値は、getByteFrequencyData()の使用時の結果の範囲の最小値として明記される。

+
+
{{domxref("AnalyserNode.maxDecibels")}}
+
+

unsigned byte型値へ変換するFFT分析データのスケーリング時の最大のパワー値を表すdouble型の値である。一般的に、この値は、getByteFrequencyData()の使用時の結果の範囲の最大値として明記される。

+
+
{{domxref("AnalyserNode.smoothingTimeConstant")}}
+
分析フレームの平均間隔を表すdouble型の値で、使用例として時間的にスペクトルを平滑化させるのに用いられる。
+
+ +

Methods

+ +

{{domxref("AudioNode")}}からメソッドを継承する.

+ +
+
{{domxref("AnalyserNode.getFloatFrequencyData()")}}
+
周波数データを引数として渡されたFloat32Array配列へコピーする。
+
+ +
+
{{domxref("AnalyserNode.getByteFrequencyData()")}}
+
周波数データを引数として渡されたUint8Array配列(unsigned byte配列)へコピーする。
+
+ +
+
{{domxref("AnalyserNode.getFloatTimeDomainData()")}}
+
音声波形データを引数として渡されたFloat32Array配列へコピーする。
+
{{domxref("AnalyserNode.getByteTimeDomainData()")}}
+
音声波形データを引数として渡されたUint8Array配列(unsigned byte配列)へコピーする。
+
+ +

Examples

+ +
+

Note: オーディオヴィジュアライゼーションのためのWeb Audio APIを使ったヴィジュアライゼーションガイドを御覧ください。

+
+ +

Basic usage

+ +

以下の例では、AudioContextから1つのAnalyserNodeを作成しており、requestAnimationFrameと<canvas>へ繰り返し時間波形データを繰り返し集め現入力を“オシロスコープスタイル”で出力し描画している。

+ +

より多くのサンプルは 我々の Voice-change-O-matic デモにご覧頂けます。 (see app.js lines 128–205 for relevant code).

+ +
var audioCtx = new (window.AudioContext || window.webkitAudioContext)();
+var analyser = audioCtx.createAnalyser();
+
+  ...
+
+analyser.fftSize = 2048;
+var bufferLength = analyser.frequencyBinCount;
+var dataArray = new Uint8Array(bufferLength);
+analyser.getByteTimeDomainData(dataArray);
+
+// draw an oscilloscope of the current audio source
+
+function draw() {
+
+      drawVisual = requestAnimationFrame(draw);
+
+      analyser.getByteTimeDomainData(dataArray);
+
+      canvasCtx.fillStyle = 'rgb(200, 200, 200)';
+      canvasCtx.fillRect(0, 0, WIDTH, HEIGHT);
+
+      canvasCtx.lineWidth = 2;
+      canvasCtx.strokeStyle = 'rgb(0, 0, 0)';
+
+      canvasCtx.beginPath();
+
+      var sliceWidth = WIDTH * 1.0 / bufferLength;
+      var x = 0;
+
+      for(var i = 0; i < bufferLength; i++) {
+
+        var v = dataArray[i] / 128.0;
+        var y = v * HEIGHT/2;
+
+        if(i === 0) {
+          canvasCtx.moveTo(x, y);
+        } else {
+          canvasCtx.lineTo(x, y);
+        }
+
+        x += sliceWidth;
+      }
+
+      canvasCtx.lineTo(canvas.width, canvas.height/2);
+      canvasCtx.stroke();
+    };
+
+    draw();
+ +

Specifications

+ + + + + + + + + + + + + + +
SpecificationStatusComment
{{SpecName('Web Audio API', '#the-analysernode-interface', 'AnalyserNode')}}{{Spec2('Web Audio API')}} 
+ +

Browser compatibility

+ +
{{CompatibilityTable}}
+ +
+ + + + + + + + + + + + + + + + + + + +
FeatureChromeFirefox (Gecko)Internet ExplorerOperaSafari (WebKit)
Basic support{{CompatChrome(10.0)}}{{property_prefix("webkit")}}{{CompatGeckoDesktop(25.0)}} {{CompatNo}}15.0 {{property_prefix("webkit")}}
+ 22
6.0{{property_prefix("webkit")}}
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + +
FeatureAndroidFirefox Mobile (Gecko)Firefox OSIE MobileOpera MobileSafari MobileChrome for Android
Basic support{{CompatUnknown}}26.01.2{{CompatUnknown}}{{CompatUnknown}}{{CompatUnknown}}33.0
+
+ +

See also

+ + -- cgit v1.2.3-54-g00ecf