字节跳动Tiktok团队北上广深杭急招前后端开发,绿色内推邮箱:sunmaoyu@bytedance.com

直播视频在微信内自动播放

为了更加方便的准确判断网络状态,只判断微信和QQ内,无线网状态下自动播放视频:

因为微信限制了直播类视频的自动播放,我们需要做些特殊处理:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
//无线网自动播放:微信qq
   var netType = getNetType(),
       platformType = getPlatformType();
 
   if(netType == 'WIFI'){
       if(platformType != 'wechat'){
       document.getElementById('video').play();//非微信内没有限制,直接触发播放视频
 
    }
    wx.ready(function(){//微信内,必须需要等到wx jsapi加载完成之后才能执行播放视频的动作
           document.getElementById('video').play();
      //为防止开播失败,尝试在8s内不断请求开播
           var myVid=document.getElementById("video");
           var _now_time = Date.now();
 
           var play_interval = setInterval(function(){
               var _new_time = Date.now();
               if(_new_time - _now_time < 8000 && myVid.played.length == 1){
                   document.getElementById('video').play();
                   clearInterval(play_interval);
               }
               if(_new_time - _now_time >= 8000){
                   clearInterval(play_interval);
               }
           },200);
       })
        
   }

  

以上处理,目前可以做到在QQ内自动播放。微信内,ios可以自动播放,安卓目前仍然自动播放失败。

QQ浏览器移动论坛已记录此问题,待以后会有更规范的解决方案。

 

吐槽:

在找解决方案过程,发现网上有人用

WeixinJSBridgeReady

这个是旧的jssdk, 最新的是wx.ready()方式

但微信的官方文档并没有说明,会产生一些误导,以下是在微信官方找到的三个版本,我用的是版本1

微信JSAPI:

版本1(新版):http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html

版本2(新版副本):https://mp.weixin.qq.com/advanced/wiki?t=t=resource/res_main&id=mp1483682025_enmey

版本3(旧版):http://qydev.weixin.qq.com/wiki/index.php?title=WeixinJS%E6%8E%A5%E5%8F%A3&oldid=287

 

posted @   冒雨ing  阅读(8129)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示