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時間來實現播放進度的監聽
在此案例中
要實現第一段視頻播放完,出現選項給用戶進行視頻的選擇交互。
我們需要在出現選項時將視屏暫停,
先來看下代碼:
該案例使用了定時器,在視頻開始事件觸發時開始每20ms觸發一次,判斷當前視頻進度,若到達需停止的進度時(第一段片段播放完畢,或選項片段結束時),暫停視頻,并出現浮層div塊,為用戶提供交互。
點擊選項后跳到對應的進度,繼續播放視頻。以上為該案例主要需要解決的問題。
安卓瀏覽器左上角會出現推出播放的返回按鈕,當點擊按鈕時將退出播放
退出播放時,我們需要做相應的處理。TBS 有提供相應的事件,不過不同的版本有一點差異
在對話框中發送 //gettbs 可以查看相關信息,tbsCoreVersion 就是當前安裝的 TBS 內核版本。
補充資料:
H5視頻播放優化:
http://www.xuanfengge.com/htm...
videoAPI:
http://www.w3school.com.cn/ta...
總結
以上是生活随笔為你收集整理的H5实例教学--微信内嵌视频1(案例浅析)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Maven学习(一)——Maven入门
- 下一篇: css 背景和渐变