iOS 微信端背景音乐自动播放和控制
2017-09-02 本文已影响0人
方防访放
iOS 微信端背景音乐自动播放和控制
所有的应用都是有其对应的应用场景,没有最好只有适合。
背景
由于个人不太擅长css布局,也不喜欢。目的是要完成一些营销活动的H5页面,涉及到一些互动小游戏,音视频,动画等等。用css个人感觉略显麻烦,于是入坑Canvas解决方案。对比了几个h5游戏引擎,LayaAir支持As,Ts和Js三种方式开发,号称性能很好。于是直接上手。
遇到的第一个问题就是音频了,不是引擎本身的问题,iOS机制的问题,iOS设备浏览器只能在用户主动触发的的点击事件里才能播放,不然会被拦截,而且只要触发一次就行了。通过js各种模拟的点击事件都不行,必须用户主动点。
好在大部分的活动是基于微信客户端。只用考虑微信环境下。原生的Safari下还是没办法。
解决办法
原理都一样,通过微信的jssdk的事件,一定要考虑jssdk的引入的初始化是否完成
//页面上写一个id为bgm的audio标签
//方式一
try {
window.WeixinJSBridge.invoke("getNetworkType", {}, bgmPlay);
}catch (e) {
bgmPlay();
}
function bgmPlay(){
$("#bgm")[0].play();
}
//方式二
wx.ready(function () {
bgmPlay();
});