AudioBuffer:duration 属性

基线 广泛可用

此功能已得到良好建立,并且可以在许多设备和浏览器版本中使用。它自以下时间起在所有浏览器中都可用 2021 年 4 月.

duration 属性是 AudioBuffer 接口的一个属性,它返回一个双精度浮点数,表示缓冲区中存储的 PCM 数据的持续时间(以秒为单位)。

一个双精度浮点数。

示例

js
// Stereo
const channels = 2;

// Create an empty two second stereo buffer at the
// sample rate of the AudioContext
const frameCount = audioCtx.sampleRate * 2.0;
const myArrayBuffer = audioCtx.createBuffer(2, frameCount, audioCtx.sampleRate);

button.onclick = () => {
  // Fill the buffer with white noise;
  // just random values between -1.0 and 1.0
  for (let channel = 0; channel < channels; channel++) {
    // This gives us the actual ArrayBuffer that contains the data
    const nowBuffering = myArrayBuffer.getChannelData(channel);
    for (let i = 0; i < frameCount; i++) {
      // Math.random() is in [0; 1.0]
      // audio needs to be in [-1.0; 1.0]
      nowBuffering[i] = Math.random() * 2 - 1;
    }
  }

  console.log(myArrayBuffer.duration);
};

规范

规范
Web Audio API
# dom-audiobuffer-duration

浏览器兼容性

BCD 表格仅在启用 JavaScript 的浏览器中加载。

另请参阅