frequencyBinCount
只读特性在
AnalyserNode
interface is an unsigned integer half that of the
AnalyserNode.fftSize
. This generally equates to the number of data values you will have to play with for the visualization.
var arrayLength = analyserNode.frequencyBinCount;
An unsigned integer, equal to the number of values that
AnalyserNode.getByteFrequencyData()
and
AnalyserNode.getFloatFrequencyData()
copy into the provided
TypedArray
.
For technical reasons related to how the
Fast Fourier transform
is defined, it is always half the value of
AnalyserNode.fftSize
. Therefore, it will be one of
16
,
32
,
64
,
128
,
256
,
512
,
1024
,
2048
,
4096
,
8192
,和
16384
.
The following example shows basic usage of an
AudioContext
to create an
AnalyserNode
,那么
requestAnimationFrame
and
<canvas>
to collect frequency data repeatedly and draw a "winamp bargraph style" output of the current audio input. For more complete applied examples/information, check out our
Voice-change-O-matic
demo (see
app.js lines 128–205
for relevant code).
var audioCtx = new (window.AudioContext || window.webkitAudioContext)();
var analyser = audioCtx.createAnalyser();
analyser.minDecibels = -90;
analyser.maxDecibels = -10;
...
analyser.fftSize = 256;
var bufferLength = analyser.frequencyBinCount;
console.log(bufferLength);
var dataArray = new Uint8Array(bufferLength);
canvasCtx.clearRect(0, 0, WIDTH, HEIGHT);
function draw() {
drawVisual = requestAnimationFrame(draw);
analyser.getByteFrequencyData(dataArray);
canvasCtx.fillStyle = 'rgb(0, 0, 0)';
canvasCtx.fillRect(0, 0, WIDTH, HEIGHT);
var barWidth = (WIDTH / bufferLength) * 2.5 - 1;
var barHeight;
var x = 0;
for(var i = 0; i < bufferLength; i++) {
barHeight = dataArray[i];
canvasCtx.fillStyle = 'rgb(' + (barHeight+100) + ',50,50)';
canvasCtx.fillRect(x,HEIGHT-barHeight/2,barWidth,barHeight/2);
x += barWidth;
}
};
draw();
| 规范 | 状态 | 注释 |
|---|---|---|
|
Web 音频 API
The definition of 'frequencyBinCount' in that specification. |
工作草案 |
| 桌面 | 移动 | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
frequencyBinCount
|
Chrome 14 | Edge 12 | Firefox 25 | IE 不支持 No | Opera 15 | Safari 6 | WebView Android Yes | Chrome Android 18 | Firefox Android 26 | Opera Android 14 | Safari iOS 6 | Samsung Internet Android 1.0 |
完整支持
不支持
AnalyserNode
fftSize
frequencyBinCount
maxDecibels
minDecibels
smoothingTimeConstant
AudioBuffer
AudioBufferSourceNode
AudioContext
AudioContextOptions
AudioDestinationNode
AudioListener
AudioNode
AudioNodeOptions
AudioParam
AudioProcessingEvent
AudioScheduledSourceNode
AudioWorklet
AudioWorkletGlobalScope
AudioWorkletNode
AudioWorkletProcessor
BaseAudioContext
BiquadFilterNode
ChannelMergerNode
ChannelSplitterNode
ConstantSourceNode
ConvolverNode
DelayNode
DynamicsCompressorNode
GainNode
IIRFilterNode
MediaElementAudioSourceNode
MediaStreamAudioDestinationNode
MediaStreamAudioSourceNode
OfflineAudioCompletionEvent
OfflineAudioContext
OscillatorNode
PannerNode
PeriodicWave
StereoPannerNode
WaveShaperNode