加载音频缓冲区并使用音频标签播放

Lan*_*nbo 7 html javascript html5-audio

我正在尝试从 URL 加载音频缓冲区,然后播放它。我从这个HTML5 Rocks 教程中得到了大部分代码。

var request = new XMLHttpRequest();
request.open('GET', $(this).attr('data-url'), true);
request.responseType = 'arraybuffer';

request.onload = function() {
    console.log(request);
    context.decodeAudioData(request.response, function(buffer) {
        console.log(buffer);
        $('#play').click(function() {
              var source = context.createBufferSource();
              source.connect(context.destination);
              source.noteOn(0);
        }).removeAttr('disabled');
    }, function(err) { console.log(err); });
};
request.send();
Run Code Online (Sandbox Code Playgroud)

但是,然后我按下#play按钮,没有任何反应。source.noteOn(0)被调用,我使用调试器检查了它。并且所有对象都已正确加载和创建,但我听不到声音。

此外,看起来,当我使用这种方法时,我需要重建一个具有所有控件的完整播放器。我今天准备这样做,保存工作,并更好地保证这个作品,是把buffer<audio/>,因此它可以在那里玩。

我知道audio.src将文件名放在那里,但我需要使用音频缓冲区。我试过了

audio.src = buffer;
audio.load()
Run Code Online (Sandbox Code Playgroud)

但这没有用。

有什么资料吗?

sib*_*bbl 12

为了回答真正的问题而不是“不要使用音频元素”,我想提供另一种解决方案。我想向用户展示音频控件,因此我需要针对所问问题的解决方案。

实际上,您只需要将ArrayBuffera转换为 a Blob,获取它的 URL 并将其映射到<audio>元素的src属性:

const blob = new Blob([arrayBuffer], { type: "audio/wav" });
const url = window.URL.createObjectURL(blob);
audioElement.src = url;
Run Code Online (Sandbox Code Playgroud)

请不要忘记相应地更改 mime 类型,不要忘记调用

window.URL.revokeObjectURL(url);
Run Code Online (Sandbox Code Playgroud)

卸载页面/组件以进行垃圾收集时。

  • 请注意,如果您需要解码 arrayBuffer,这将分离缓冲区,因此您将无法创建 blob。解决方案:获取数组缓冲区,创建 blob,解码数组缓冲区。 (2认同)

kr1*_*kr1 2

如果您只想播放音频文件,<audio>为了简单起见,您可能需要使用该标签。(并且不限于 webkit 浏览器)。

在您的示例中,您没有设置缓冲区源节点的缓冲区:
如果您想保留整体结构,您可以简单地添加行source.buffer = buffer,例如:

context.decodeAudioData(request.response, function(buffer) {
    $('#play').click(function() {
          var source = context.createBufferSource();
          source.buffer = buffer;
          source.connect(context.destination);
          source.noteOn(0);
    }).removeAttr('disabled');
}, function(err) { console.log(err); })
Run Code Online (Sandbox Code Playgroud)

(通过将音频解码与事件处理分开,可以提高代码的可读性)。

您的其他问题audio.src
您应该设置audio.src为音频文件的URL 。