iOS 12 静音模式下 AudioContext 无法正常播放的 Bug

栏目: JavaScript · 发布时间: 7年前

内容简介:最近收到用户反馈,网页的背景音乐播放没有声音。然后我们就按照正常的流程 Debug 。但是我拿到我的 iPhone 7 测试的时候,但是发现是可以正常播放的,但是 iPhone XS 确没有办法播放。 而且这次非常悬疑的是,iPhone XS 的又是可以正常播放虾米音乐的的歌曲。此时此刻,宝宝的心情,只能用如下图表示:

最近收到用户反馈,网页的背景音乐播放没有声音。

然后我们就按照正常的流程 Debug 。但是我拿到我的 iPhone 7 测试的时候,但是发现是可以正常播放的,但是 iPhone XS 确没有办法播放。 而且这次非常悬疑的是,iPhone XS 的又是可以正常播放虾米音乐的的歌曲。

此时此刻,宝宝的心情,只能用如下图表示:

iOS 12 静音模式下 AudioContext 无法正常播放的 Bug

iOS 12 静音模式下 AudioContext 无法正常播放的 Bug

随后开始看代码,项目的背景音乐是启用了 AudioContext 。这个时候我们强制设置 AudioContext 的音量来,看下是不是 iPhone XS 的问题;

const audioCtx = new AudioContext();  
let source = aCtx.createBufferSource();  
let buf;

const gainNode = aCtx.createGain(); // Create a gainNode reference.  
gainNode.connect(aCtx.destination); // Add context to gainNode

fetch('./test.mp3') // can be XHR as well  
      .then(resp => resp.arrayBuffer())
      .then(buf => aCtx.decodeAudioData(buf)) // can be callback as well
      .then(decoded => {
        source.buffer = buf = decoded;
        source.loop = true;

        source.connect(gainNode);   //Connecting gain to source
        gainNode.gain.value = 1;  // 100% VOLUME RANGE OF VALUE IS 0-1
      });

可是还是没有效果啊~

iOS 12 静音模式下 AudioContext 无法正常播放的 Bug

自己随后想到是不是 Safari 的 Media Policy 的控制,嗯,一搜果真搜到了,

https://gist.github.com/kus/3f01d60569eeadefe3a1

我们需要在用户点击屏幕的时候将 AudioContext 激活,使它的状态由 suspended 变为 running 。

if (context.state === 'suspended' && 'ontouchstart' in window)  
{
    var unlock = function()
    {
        context.resume();
    };

    document.body.addEventListener('touchstart', unlock, false);
}

这个时似乎感觉离新大陆近了,

iOS 12 静音模式下 AudioContext 无法正常播放的 Bug

然而测试下来,还是没有声音。。。。

这个时候楼主,默默拿起了 iPhone 7 和 XS 看了下,发现XS 的左边的静音键按下了。。。。

iOS 12 静音模式下 AudioContext 无法正常播放的 Bug

取消静音模式,音频正常播放了,因此如果要解决这个问题,建议大家还是用 Audio 元素来弄, AudioContext 应该是 Safari 保持的一个 Media 策略。

扩展阅读


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

精通Android游戏开发

精通Android游戏开发

[美] Vladimir Silva / 王恒、苏金国 等 / 人民邮电出版社 / 2011-2 / 45.00元

作为引领移动技术潮流的软件平台,Android发布了NDK以支持Java和C的混合开发,使PC游戏可以在Android平台上焕发更多魅力。 本书是为那些在Android游戏开发工作中寻求突破的人准备的。书中不仅通过Space Blaster和Asteroids这两个炫酷 的街机游戏深入介绍了如何从头构建纯Java游戏,更详细展示了如何将PC上的3D经典游戏Doom和Wolfenstein 3......一起来看看 《精通Android游戏开发》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具