整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          如何制作一個完美的全屏視頻H5

          在前面的話:

          最近一波H5廣告火爆整個互聯(lián)網(wǎng)圈,身為圈內(nèi)人,我們怎能 不! 知!道!


          :( 噓!真不知道的也繼續(xù)看下去,有收獲 ↓ )

          So,搞懂這個并不難。

          這篇文章將帶你從頭到尾了解H5廣告的實現(xiàn)。


          本文主要講一下幾個關(guān)鍵點

          一、視頻內(nèi)聯(lián)播放。

          -- 想要營造一種文字與視頻混排的現(xiàn)象,視頻不要影響其他模塊


          二、視頻去控件。

          -- 交互視頻,不能點擊快/慢進(jìn)或暫停哦


          三、去控件全屏播放。

          -- 想要模擬 明星給我打電話的體驗,不能看到明顯的視頻播放器


          四、視頻自動播放。

          -- 想要釋放用戶操作,打開鏈接就自動播放

          五、黑屏問題。

          -- 開始播放時,有一段黑屏?xí)r間,不能無縫銜接

          六、其他屬性和方法。

          -- 喜歡一個技術(shù),就要了解“她”的全部,這些你也看看唄





          一、video 標(biāo)簽內(nèi)聯(lián)播放



          Video 標(biāo)簽內(nèi)聯(lián)播放,需要添加屬性:

          webkit-playsinline="true" playsinline=“true”



          通過上述代碼可以達(dá)到蘋果手機(jī)非全屏(內(nèi)聯(lián))播放的效果,安卓上退出全屏后也可以通過底部的播放按鈕非全屏播放。


          而在 iphone上 默認(rèn)是全屏播放的。

          需要在 Obj-C 里,webview設(shè)置allowsInlineMediaPlayback屬性為YES
          webview.allowsInlineMediaPlayback = YES;


          這個需要客戶端的同學(xué)注意一下。


          iOS 10 之前的版本支持 webkit-playsinline,但是加了這個屬性后,在 iOS 9 上出現(xiàn)只能聽到聲音不能看到畫面的問題。

          為了 兼容ios8、9 需要再加上這個庫 iphone-inline-video 一起使用。

          [https://github.com/bfred-it/iphone-inline-video]


          這里補(bǔ)充一下 iphone-inline-video 使用方法:

          1.npm install --save iphone-inline-video

          2.使用



          iphone-inline-video在iOS 10上會自動禁用。

          確保你使用這個playsinline屬性。




          二、播放視頻去控件


          實現(xiàn)上圖效果,可添加CSS:


          此方法僅適用于 非全屏下去掉控件。



          三、去控件全屏播放




          實現(xiàn)去控件全屏播放步驟:

          1、全屏實現(xiàn):將video視頻寬高設(shè)置為 100% (全屏)

          2、去控件參照上面說的第二步


          當(dāng)然,如果想要實現(xiàn)真正的全屏(頂部的導(dǎo)航消失),針對x5內(nèi)核的可以使用 同層播放器。

          新版的 TBS 內(nèi)核(>=036849)支持同層播放器的視頻播放器,且不需要申請白名單。


          只需給 video 設(shè)置兩個屬性 x5-video-player-type="h5" 和 x5-video-player-fullscreen="true",播放效果自然服帖,效果如上圖。




          四、視頻自動播放


          設(shè)置屬性 autoplay

          But , Android始終不能自動播放,需要手動調(diào)用:


          開發(fā)中,遇到一個問題,在微信中始終無法實現(xiàn)自動播放,因為IOS和微信都是要求用戶有操作后才能自動播放影音視頻。

          這里,找到了一個hack方法:

          微信中,可以監(jiān)聽 WeixinJSBridgeReady 事件,來實現(xiàn)視頻的自動播放



          五、黑屏問題

          ios 在播放視頻時,會出現(xiàn)短暫的黑屏(透屏),再正常顯示。


          為了避免不正常顯示,我們可以這樣做:

          在視頻上層覆蓋一個 使用視頻第一幀的圖片填充的“div 塊”,制造播放假象。然后監(jiān)聽事件 timeupdate ,視頻播放有畫面時移除這個“div塊”




          六、常用屬性和事件

          video 支持的屬性和事件很多,但在有些屬性和事件在不同的系統(tǒng)上跟預(yù)想的表現(xiàn)不一致,在嘗試比較之后,以下基本可以滿足需求:


          1、autoplay 屬性


          <video autoplay="true" />


          設(shè)置此屬性,視頻將自動播放。


          2、preload 屬性


          <video preload="auto” />


          規(guī)定是否預(yù)加載視頻。

          可能的值:

          * auto - 當(dāng)頁面加載后載入整個視頻

          * meta - 當(dāng)頁面加載后只載入元數(shù)據(jù)

          * none - 當(dāng)頁面加載后不載入視頻


          如果設(shè)置了 autoplay 屬性,則忽略該屬性。


          3、timeupdate 事件

          監(jiān)聽音頻/視頻(audio/video)的播放位置發(fā)生改變時觸發(fā)。通常與 video.currentTime 一同使用





          4、ended 事件

          監(jiān)聽視頻播放結(jié)束






          后記:

          網(wǎng)上關(guān)于video介紹的文章也挺多,通過搜集和自己的開發(fā)經(jīng)驗,這里整理了一些問題:

          • 因為視頻是一邊播放一邊加載,因此不但視頻的大小會影響加載體驗,視頻的清晰度對加載體驗影響更大。
          • 建議視頻1S平均大小范圍控制在0.09~0.17M
          • 視頻格式建議使用mp4
          • 如果 在android 環(huán)境中,想要隱藏 video 播放器,style屬性 這樣寫:{ position: relative; display: none; z-index: -1; }





          參考資料:

          https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/video

          https://x5.tencent.com/tbs/guide/video.html

          作者:大轉(zhuǎn)轉(zhuǎn) - 張穎

          來源:微信公眾號:大轉(zhuǎn)轉(zhuǎn)FE

          出處:https://mp.weixin.qq.com/s/Bz8Ra1coFirSnwsqacifVw

          里云播放器SDK(ApsaraVideo for Player SDK)是阿里視頻云端到云到端服務(wù)的重要一環(huán),除了支持點播和直播的基礎(chǔ)播放功能外,還深度融合視頻云業(yè)務(wù),支持視頻的加密播放、安全下載、首屏秒開、低延時等業(yè)務(wù)場景,為用戶提供簡單、快速、安全、穩(wěn)定的視頻播放服務(wù)。本文銜接上文,詳細(xì)介紹web播放器的功能及實現(xiàn)。

          一、基本概況及功能

          • 播放器架構(gòu)

          Aliplayer Web播放器分為H5和Flash兩個,F(xiàn)lash播放器隨著技術(shù)的發(fā)展會逐漸被邊緣化,所以我們以后只做維護(hù),不會更新功能了,重點會放在H5播放器上。H5播放器架構(gòu)主要分四層,底層H5 Video,播放能力和H5原生Video緊密相關(guān)。第二層是基礎(chǔ)播放器,它不依賴于具體業(yè)務(wù),通過URL的方式來播放。第三層是為各種業(yè)務(wù)場景準(zhǔn)備的不同的播放器,可以很容易的擴(kuò)展,相互隔離不依賴。最上面一層是適配的播放器,會根據(jù)終端類型、瀏覽器類型、播放格式和用戶指定來進(jìn)行智能適配。

          • 播放器功能

          最近,我們在播放器端上也實現(xiàn)了截圖、國際化、變速、UI自定義、微信同層播放、自適應(yīng)播放、加密播放、H5播放flv、自定義插件等功能。后續(xù),我們還會通過插件的形式實現(xiàn)彈幕、廣告等功能,并會開源到github上,也會支持用戶根據(jù)自己業(yè)務(wù)需求來自定義SDK包。

          • 播放器支持視頻格式

          • 適配播放

          我們整個視頻播放的基本原則是H5優(yōu)先,能用H5播放的肯定不用Flash去播放。所以在移動端,我們肯定是用H5來播放的,PC端也依照這個原則盡量使用H5。同時,我們會判斷瀏覽器類型支持哪種播放格式,比如m3u8在PC端IE11以上的瀏覽器才能播放,如果遇到IE11以下的瀏覽器,我們自動會選擇Flash播放。在視頻格式方面,假設(shè)視頻是rtmp和flv,我們會自動選擇Flash播放。另外,如果用戶自主設(shè)置useH5Prism和useFlashPrism屬性,那我們也會依照用戶的選擇。

          • 瀏覽器支持情況

          FLASH支持IE8以上,在瀏覽器上啟動允許FLASH運(yùn)行即可;H5支持IE9以上,m3u8需要在IE11以上才可以運(yùn)行;其他瀏覽器都也都是可以支持的。

          • 兩種播放方式

          1. source,通過url 去播放

          2. 通過點播vid+playauth去播放,第二種方式和視頻云結(jié)合比較緊密

          • 點播播放格式的選擇

          點播服務(wù)中轉(zhuǎn)碼生成的視頻格式有很多,包括m3u8、flv、mp4等。播放器有自己的一套邏輯去選擇播放格式。對于H5來說,默認(rèn)播放低清版本來節(jié)省流量,如果用戶使用了切換清晰度的功能,那我們會默認(rèn)打開他選擇的版本。格式方面,則默認(rèn)播放mp4,用戶也可以設(shè)置qualitySort來優(yōu)先播放高清的的版本。對于Flash來說,默認(rèn)格式順序是m3u8、flv、mp4。

          二、功能介紹及啟用

          • 創(chuàng)建播放器

          1. 引用正確的JS和CSS文件

          2. 添加播放器容器 需要設(shè)置容器的id屬性,另外2.0.1之前的版本要添加prism-player類型。

          • New Aliplayer創(chuàng)建播放

          • 在線配置,用戶可以預(yù)先體驗下播放器的情況

          • Aliplayer-Cli創(chuàng)建演示例子

          用戶需要演示例子的時候,不需要寫很多代碼,通過這個命令,就可以創(chuàng)建例子,直接體驗AliPlayer。

          • PC端支持m3u8

          播放域名啟用允許跨域訪問

          • 訂閱和取消事件

          • 清晰度切換

          H5 1.9.9以后的版本和id+playauth播放方式才支持清晰度切換;支持記憶選擇的清晰度,當(dāng)選擇的清晰度不能播放時,自動選擇下一個清晰度播放。

          • 手動切換視頻-H5

          這個功能播放器內(nèi)比較常見。我們把它分成兩種情況去處理,如果是地址播放,我們通過loadByUrl來播放;如果是vid+playauth播放,我們通過replayByVidAndPlayAuth的方法來播放。

          • 手動切換視頻-flash

          地址播放方法與H5的方法一樣,vid+playauth播放則需要先銷毀播放器,再重新創(chuàng)建播放。

          • 不同地址格式的切換

          只能先銷毀播放器,再重新選擇正確的播放器播放。Github地址看simple demo:https://github.com/alilmq/aliplayer-simple-demo

          ![b_3_7]

          • UI自定義

          很多用戶有這個需求,所以我們的UI是可以隱藏掉的。提供了一個skinLayout的屬性,當(dāng)這個屬性沒有指定值的時候,UI組件是全部顯示。如果是空數(shù)組的時候,UI組件全部不顯示。并且可以自定義組件的顯示和位置,在默認(rèn)UI基礎(chǔ)上去裁剪,2.3.0版本以后,用戶也可以通過自定義插件的方式自定義自己的UI。

          • 截屏

          H5啟用:

          FLASH啟用:snapshot:true

          H5播放器,播放域名需添加允許跨域訪問的header

          支持訂閱snapshoted事件,獲取截屏的時間點和數(shù)據(jù):

          支持設(shè)置截圖的大小和質(zhì)量:

          支持添加文字水印:

          • 邊轉(zhuǎn)變播功能

          邊轉(zhuǎn)邊播是MTS的功能,播放器可以支持這種場景的播放。第一次觀看的時候調(diào)用MTS API啟動轉(zhuǎn)碼,邊轉(zhuǎn)碼邊播放,而且可以設(shè)置延遲播放。轉(zhuǎn)碼中使用直播播放器,轉(zhuǎn)碼完成后使用點播方式播放。

          • H5 android微信同層播放

          因為H5在android端微信打開時,會自動全屏播放,覆蓋Dom元素。

          同層播放一般有兩種業(yè)務(wù)場景,一種是點播的,視頻在某個地方播放,下面的評論、播放列表等,demo地址:https://github.com/alilmq/h5demo

          還要一種場景是直播場景,視頻需要全屏。可以通過設(shè)置x5_type:h5啟用同層播放。Demo 地址:https://github.com/alilmq/h5livedemo

          另外H5微信同層播放,有兩篇文章可以參考:

          http://player.alicdn.com/aliplayer/docs/blogs/how-to-handle-h5-same-layer.html

          http://player.alicdn.com/aliplayer/docs/blogs/how-to-handle-h5-same-layer.html

          • 國際化

          提供language屬性,用于啟用各種語言,默認(rèn)為zh-cn,可選值為zh-cn or en-us。

          • 倍速播放

          提供UI的版本,只提供了0.5、1、1.5、2四種倍速播放;而setspeed方法,可以隨意設(shè)置倍速播放。這個可能會有一些限制,移動端有的瀏覽器會不支持,比如android微信。

          • 對于直播播放失敗的處理

          在播放失敗時候,會嘗試重新播放,觸發(fā)onM3u8Retry事件,事件里可以做一些提示,比如主播離開請稍等;如果幾次嘗試后還是失敗,會出發(fā)livestreamstop事件,事件里做一些直播失敗或結(jié)束的提示。


          三、其他輔助功能及工具

          我們也做了一些輔助工具,方便用戶去接入和排查問題。

          • 診斷工具

          通過錯誤碼描述的映射關(guān)系,大概能知道用戶的錯誤所在;

          通過vid知道用戶播放的是哪個視頻;

          通過uuid這個唯一標(biāo)識,可以在日志系統(tǒng)中查到用戶的播放狀態(tài);

          通過requestid和播放時間,可以定位到用戶的錯誤是哪次播放的錯誤和具體的播放時間。

          這里還有一個診斷的功能,可以知道用戶環(huán)境的具體信息,省去手工獲取視頻的繁瑣,可以快速診斷問題。

          地址:http://player.alicdn.com/detection.html

          • 檢測工具

          關(guān)于視頻播放失敗,我們提供了三種方式,原生H5、阿里云H5、阿里云Flash。我們把播放的日志調(diào)出來,通過日志來情況來判斷播放失敗的原因。舉個例子,如果用戶剛開始請求數(shù)據(jù)時就失敗的話,那我們會猜測存在鑒權(quán)失敗的情況;如果加載數(shù)據(jù)出錯,那可能是用戶的網(wǎng)絡(luò)的原因;如果是開始播放后出錯,可能就問題就出在解析或播放器不支持等方面。

          • ffmpeg查看視頻信息

          有的用戶只有畫面,沒有聲音。我們可以通過ffmpeg可以看下視頻的格式、流的情況、碼率、幀率等。

          最后,阿里云播放器的所有情況都聚合在以下的網(wǎng)站上:

          http://player.alicdn.com/detection.html,其中包括幫助文檔、在線配置、診斷工具、產(chǎn)品demo等,大家可以登錄了解詳情。

          天給大家分享一個可以將視頻作為網(wǎng)頁背景的插件!效果展示地址:http://39.108.141.146/

          需要源代碼的童鞋評論里留個郵箱或者私信我也可以,我發(fā)給你們!

          效果截圖

          下載源碼解壓!

          項目結(jié)構(gòu)圖

          我們將想要展示的視頻存放在assets文件夾,然后右鍵點擊index.html選擇用記事本打開,如下圖,修改視頻地址!

          如何修改視頻背景

          index2.html是全屏作為背景,修改方式和index.html一樣的!

          修改完后點擊保存,然后用瀏覽器分別打開這兩個文件就可以看到效果了!

          當(dāng)然也可以發(fā)布到網(wǎng)上給別人看!發(fā)布的方法→原來自己建網(wǎng)站這么簡單!


          主站蜘蛛池模板: 日韩电影在线观看第一区| 久久se精品一区二区影院| 无码日本电影一区二区网站| 日韩少妇无码一区二区三区| 91福利一区二区| 国产午夜福利精品一区二区三区| 国产熟女一区二区三区四区五区 | 美女视频黄a视频全免费网站一区| 国产精品一区在线麻豆 | 成人日韩熟女高清视频一区| 亚洲日本一区二区一本一道| 日本一区二区不卡在线| 亚洲一区中文字幕久久| 中文字幕不卡一区| 全国精品一区二区在线观看| 日本不卡免费新一区二区三区| 久久一区二区免费播放| 一区二区精品视频| 无码精品前田一区二区| 乱色精品无码一区二区国产盗| 国产成人午夜精品一区二区三区| 国产凸凹视频一区二区| 韩国福利视频一区二区| 在线观看中文字幕一区| 亚洲国产精品一区二区第一页| 夜色福利一区二区三区| 午夜爽爽性刺激一区二区视频| 国产一区二区三区不卡AV| 国产免费一区二区三区| 无码精品人妻一区二区三区影院 | 国产精品夜色一区二区三区| 国产精品久久一区二区三区| 人妻夜夜爽天天爽一区| 日韩一本之道一区中文字幕| 国产精品 一区 在线| 久久人做人爽一区二区三区| 国语对白一区二区三区| 色婷婷综合久久久久中文一区二区 | 国产AV一区二区三区无码野战| 国产精品一区二区av不卡| 一区二区三区久久精品|