video blob 視頻優(yōu)化

在處理視頻的時(shí)候庙睡,最基本的用法就是通過video來引入著角,但使用上總有些缺陷揪漩,例如視頻源暴露問題,以及資源的播放加載問題吏口,于是乎特地去看專業(yè)的視頻網(wǎng)站的做法奄容,發(fā)現(xiàn)他們的鏈接地址中都包含了blob

<video src="blob:http://www.bilibili.com/d0823f0f-2b2a-4fd6-a93a-e4c82173c107"></video>

打開鏈接的時(shí)候,卻顯示了404产徊,查閱了資料昂勒,才知道這是視頻”分段緩沖播放“處理,通過 MediaSourcecreateObjecturl 的配合舟铜。

那么如何處理呢戈盈,直接上代碼:

//先創(chuàng)建變量名為 `video` 的 DOM 對象
var video = document.querySelector('video');  

// 創(chuàng)建MediaSource對象
var mediaSource = new MediaSource;  

// 將mediaSource通過createObjecturl函數(shù)賦值給src
video.src = URL.createObjectURL(mediaSource);  

// 監(jiān)聽sourceopen事件,當(dāng)video產(chǎn)生src時(shí)谆刨,處理視頻數(shù)據(jù)
mediaSource.addEventListener('sourceopen', sourceOpen) 

function sourceOpen () {
    var mediaSource = this;
    
    // 構(gòu)建一個(gè)存放視屏數(shù)據(jù)的 Buffer
    var sourceBuffer = mediaSource.addSourceBuffer('video/mp4; codecs="avc1.42E01E, mp4a.40.2"');  
  
    // 監(jiān)聽updateend事件塘娶,數(shù)據(jù)加載完畢就播放視頻
    sourceBuffer.addEventListener('updateend', function () {
        mediaSource.endOfStream();      
        video.play(); 
    });
    
    // 添加緩沖數(shù)據(jù),buf是用于存儲視頻數(shù)據(jù)的緩沖數(shù)組
    sourceBuffer.appendBuffer(buf);  
};

邏輯是這樣的:

先創(chuàng)建變量名為 video 的 DOM 對象痊夭。之后刁岸,創(chuàng)建變量名為 mediaSourceMediaSource 對象。 通過函數(shù) createObjecturl 來將 DOM::Video 對象的屬性 srcmediaSource 進(jìn)行“連接”她我。 接下來虹曙,通過注冊事件 Event::sourceopen 來觸發(fā)當(dāng)上述“連接”結(jié)束之后的回調(diào)處理》撸回調(diào)處理就是需要賦值 視頻數(shù)據(jù) 的地方根吁。 調(diào)用 MediaSource::addSourceBuffer 方法來構(gòu)建一個(gè)存放視屏數(shù)據(jù)的 Buffer。 在往 Buffer 中存放數(shù)據(jù)結(jié)束之后會觸發(fā)事件 Event::updateend 合蔽。 通過注冊這個(gè)事件的回調(diào)击敌,可以知曉數(shù)據(jù)已經(jīng)加載完畢,然后調(diào)用 Video::play 函數(shù)通知瀏覽器播放視頻拴事。 至此沃斤,整個(gè) Blob 運(yùn)行機(jī)制講解完畢。詳細(xì)的技術(shù)細(xì)節(jié)需要花一段時(shí)間來查看刃宵,暫時(shí)停止在這里衡瓶。我們先知道這個(gè)是什么東西。<( ̄3 ̄)>

主要使用 new MediaSourcecreateObjectURL 這2個(gè)函數(shù)牲证。(當(dāng)然實(shí)現(xiàn)不會這么簡單哮针,比如異常處理,用戶交互等都是需要巨量的代碼來覆蓋。)

最后十厢,引用一些別人的結(jié)語:

這個(gè)只是 HTML5 提供的新特性等太,但是截止目前還是處于試驗(yàn)狀態(tài)÷牛可是缩抡,現(xiàn)在已經(jīng)有許多的廠商開始使用,有大廠的支持包颁,心里稍稍安心啦瞻想。

出處:

https://creamidea.github.io/static/html/articles/HTML5-Video-Blob.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市娩嚼,隨后出現(xiàn)的幾起案子蘑险,更是在濱河造成了極大的恐慌,老刑警劉巖岳悟,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漠其,死亡現(xiàn)場離奇詭異,居然都是意外死亡竿音,警方通過查閱死者的電腦和手機(jī)和屎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來春瞬,“玉大人柴信,你說我怎么就攤上這事】砥” “怎么了随常?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長萄涯。 經(jīng)常有香客問我绪氛,道長,這世上最難降的妖魔是什么涝影? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任枣察,我火速辦了婚禮,結(jié)果婚禮上燃逻,老公的妹妹穿的比我還像新娘序目。我一直安慰自己,他們只是感情好伯襟,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布猿涨。 她就那樣靜靜地躺著,像睡著了一般姆怪。 火紅的嫁衣襯著肌膚如雪叛赚。 梳的紋絲不亂的頭發(fā)上澡绩,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天,我揣著相機(jī)與錄音俺附,去河邊找鬼肥卡。 笑死,一個(gè)胖子當(dāng)著我的面吹牛昙读,可吹牛的內(nèi)容都是我干的召调。 我是一名探鬼主播膨桥,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蛮浑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了只嚣?” 一聲冷哼從身側(cè)響起沮稚,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎册舞,沒想到半個(gè)月后蕴掏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡调鲸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年盛杰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片藐石。...
    茶點(diǎn)故事閱讀 39,764評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡即供,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出于微,到底是詐尸還是另有隱情逗嫡,我是刑警寧澤,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布株依,位于F島的核電站驱证,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏恋腕。R本人自食惡果不足惜抹锄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望荠藤。 院中可真熱鬧祈远,春花似錦、人聲如沸商源。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牡彻。三九已至扫沼,卻和暖如春出爹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缎除。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工严就, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人器罐。 一個(gè)月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓梢为,卻偏偏與公主長得像,于是被迫代替她去往敵國和親轰坊。 傳聞我的和親對象是個(gè)殘疾皇子铸董,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內(nèi)容