• 本站会放置Google广告用于维持域名以及网站服务器费用。

  • 本站由于前段时间遭受到大量临时和国外邮箱注册,所以对可注册的邮箱类型进行了限制!

  • 如果觉得本站的内容有帮助,可以考虑打赏博主哦!

  • 计算机图形学与计算几何经典必备书单整理,下载链接可参考:https://www.stubbornhuang.com/1256/

  • 问题反馈可发送邮件到stubbornhuang@qq.com

  • 在本站开通年度VIP,无限制下载本站资源和阅读本站文章

  • 感谢大家访问本站,希望本站的内容可以帮助到大家!

  • 欢迎大家交换友链,可在https://www.stubbornhuang.com/申请友情链接进行友链交换申请!

  • 工资「喂饱肚子」,副业「养活灵魂」!

Javascript – Chrome播放音频报错,The AudioContext was not allowed to start. It must be resumed (or created) ,修复音频无法播放的问题

Javascript 发布于2023-09-27 阅读 2,491次 0次评论 0次点赞 本文共1749个字,阅读需要5分钟。

1 Chrome自动播放音频报错,The AudioContext was not allowed to start. It must be resumed (or created)

1.1 问题

今天用js实现一个接收到服务器通知之后自动播放通知音频的功能,用的AudioContext播放音频,示例的音频播放代码如下

function server_notify()
{
    var audioContext = new AudioContext();
    let array_buffer = Base64Binary.decodeArrayBuffer(audio_base64_data);
    audioContext.decodeAudioData(array_buffer, function (buffer) {
        let audio_source = audioContext.createBufferSource();
        audio_source.buffer = buffer;
        audio_source.connect(audioContext.destination);
        audio_source.start(0);
       },function (e){
        console.error("decodeAudioData failed: "+ audio_base64_data);
   });
}

在本地Webstorm测试代码是正常的,可以自动播放声音,但是上线到测试服测试的时候出现了声音无法播放的问题,并输出了如下的错误

The AudioContext was not allowed to start. It must be resumed (or created) a ...

这主要是因为Chrome为了改善用户浏览体验,对音频自动播放的控制更加严格,不允许在没有用户交互下自动播放音频,具体的可看Google的官方文档:https://developer.chrome.com/blog/autoplay/#webaudio

1.2 解决方案

解决方案有很多种:

  • 添加一个按钮,在点击按钮中播放音频(不过这种方式就不是自动播放音频了)

或者可以通过这种方式

var constraints = { audio: true } // add video constraints if required

navigator.mediaDevices.getUserMedia(constraints)
.then((stream) => {
    var audioContext = new AudioContext();
    // ... rest of code
})

通过这种方式让AudioContext不进入挂起状态,并可自动播放音频。所以1.1节中的代码就修改为

function server_notify()
{
    var constraints = { audio: true }
    navigator.mediaDevices.getUserMedia(constraints).then((stream) => {
         var audioContext = new AudioContext();
        let array_buffer = Base64Binary.decodeArrayBuffer(audio_base64_data);
        audioContext.decodeAudioData(array_buffer, function (buffer) {
            let audio_source = audioContext.createBufferSource();
            audio_source.buffer = buffer;
            audio_source.connect(audioContext.destination);
            audio_source.start(0);

           },function (e){
            console.error("decodeAudioData failed: "+ audio_base64_data);
       });
    })
}

修改为这种方式就可以自动播放音频了,并且控制台就不会报1.1节的错误了。

参考

欢迎扫码关注我的微信公众号,及时获取文章更新

微信公众号二维码

本文作者:StubbornHuang

版权声明:本文为站长原创文章,如果转载请注明原文链接!

原文标题:Javascript – Chrome播放音频报错,The AudioContext was not allowed to start. It must be resumed (or created) ,修复音频无法播放的问题

原文链接:https://www.stubbornhuang.com/2821/

发布于:2023年09月27日 11:41:27

修改于:2023年09月27日 11:41:27

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

文章末尾
上一篇
C++ - Windows下实现程序开机自启动功能或者关闭开机自启动
C++
下一篇
资源分享 - Math for Deep Learning - What You Need to Know to Understand Neural Networks 英文PDF下载
AI资源
当前分类随机文章推荐

发表评论

您必须 [ 登录 ] 才能发表留言!

关注我们的公众号

微信公众号