日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

H5实例教学--微信内嵌视频1(案例浅析)

發布時間:2025/5/22 76 豆豆
生活随笔 收集整理的這篇文章主要介紹了 H5实例教学--微信内嵌视频1(案例浅析) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

以上為案例二維碼
首個H5案例解析
從頭開始分析

在 iOS 上,APP 都是使用的系統自帶的瀏覽器進行頁面渲染,video 播放視頻的效果是統一的,只需要考慮不同的 iOS 版本是否有不一致的地方。在 iOS 上,播放視頻默認會彈出一個播放器全屏播放視頻,如下效果

播放器上下有的系統默認的控制欄,可以控制視頻的播放進度、音量以及暫停或繼續播放,播放視頻時,視頻會 “浮” 在頁面上,頁面上的所有元素都只能是在視頻下面,這種效果顯然不是我們想要的。
但好在 iOS 10 Safari 中,video 新增了 playsinline 屬性,可以使視頻內聯播放。(微信瀏覽器支持)

在 webkit 的 blog 上提到

A note about the playsinline attribute: this attribute has recently been added to the HTML specification, and WebKit has adopted this new attribute by unprefixing its legacy webkit-playsinline attribute. This legacy attribute has been supported since iPhoneOS 4.0, and accordance with our updated unprefixing policy, we’re pleased to have been able to unprefix webkit-playsinline.

來源: http://www.cnblogs.com/zzsdre...
安卓實現:

TBS 內核(>=036849)支持一個叫 同層播放器 的視頻播放器,這個不需要申請白名單,只需給 video 設置兩個屬性 x5-video-player-type="h5" 和 x5-video-player-fullscreen="true",播放效果

結合IOS和安卓微信下同層播放器的實現代碼:

<video preload="load" data-link="http://wag.i-h5.cn/dj/wyf/video/wb.mp4" playsinline x-webkit-airplay="true" webkit-playsinlinex5-video-player-type="h5" x5-video-player-fullscreen="true" id="video" width="100%" src="http://wag.i-h5.cn/dj/wyf/video/wyf.mp4"></video>

稍微講一下video的事件

此案例并沒有使用timeupdate時間來實現播放進度的監聽
在此案例中
要實現第一段視頻播放完,出現選項給用戶進行視頻的選擇交互。
我們需要在出現選項時將視屏暫停,
先來看下代碼:

function getTime(obj){obj.timer = setInterval(function(){var t = obj.currentTime;if(isAndroid) {// 選項出現if(Math.abs(t - 32.13) <= .1 && istest) {selectBtn.style.display = 'block';obj.pause();clearInterval(obj.timer);}// // 墨鏡播放完必,鐲子播放完畢,帽子播放完畢if(Math.abs(t) > 46.04 && typenum == 1 || Math.abs(t) > 65.16 && typenum == 2 || Math.abs(t) > 80.64 && typenum == 4) {selectBtn.style.display = 'block';obj.pause();istest = true;clearInterval(obj.timer);}} else {// 選項出現if(Math.abs(t - 32.13) <= .1 && istest) {selectBtn.style.display = 'block';// obj.currentTime = 32.13;obj.pause();clearInterval(obj.timer);}// // 墨鏡播放完必,鐲子播放完畢,帽子播放完畢if(Math.abs(t) > 46.04 && typenum == 1 || Math.abs(t) > 65.16 && typenum == 2 || Math.abs(t) > 80.24 && typenum == 4) {selectBtn.style.display = 'block';obj.currentTime = 32.13;obj.pause();istest = true;clearInterval(obj.timer);}}// 項鏈播放,提前呼出點擊按鈕if(t > 172) {// aLink.style.display = 'block';// window.location.href = 'http://wag.i-h5.cn/dj/wyf/fenx.html';}},20); } /*** 視頻開始play*/ video.addEventListener('play', function(){// ovstatus = 1;console.log("play")getTime(this); }, false);

該案例使用了定時器,在視頻開始事件觸發時開始每20ms觸發一次,判斷當前視頻進度,若到達需停止的進度時(第一段片段播放完畢,或選項片段結束時),暫停視頻,并出現浮層div塊,為用戶提供交互。

點擊選項后跳到對應的進度,繼續播放視頻。以上為該案例主要需要解決的問題。

安卓瀏覽器左上角會出現推出播放的返回按鈕,當點擊按鈕時將退出播放
退出播放時,我們需要做相應的處理。TBS 有提供相應的事件,不過不同的版本有一點差異

TBS < 036849 036849 <= TBS < 036900 036900 <= TBS 是否支持同層播放器 否 是 是 退出全屏播放時觸發 x5videoenterfullscreen x5videoexitfullscreen 進入全屏播放時觸發 x5videoexitfullscreen x5videoenterfullscreen 通過監聽這兩個事件就可以知道當前的播放狀態document.getElementById('video').addEventListener("x5videoexitfullscreen", function(){alert("exit fullscreen") })document.getElementById('video').addEventListener("x5videoenterfullscreen", function(){alert("enter fullscreen") })

在對話框中發送 //gettbs 可以查看相關信息,tbsCoreVersion 就是當前安裝的 TBS 內核版本。

補充資料:
H5視頻播放優化:
http://www.xuanfengge.com/htm...
videoAPI:
http://www.w3school.com.cn/ta...

總結

以上是生活随笔為你收集整理的H5实例教学--微信内嵌视频1(案例浅析)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。