直播視頻在微信內自動播放


為了更加方便的准確判斷網絡狀態,只判斷微信和QQ內,無線網狀態下自動播放視頻:

因為微信限制了直播類視頻的自動播放,我們需要做些特殊處理:

 //無線網自動播放:微信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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM