欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue使用mpegts.js的詳細(xì)步驟記錄

 更新時(shí)間:2024年04月12日 09:43:37   作者:跳跳的小古風(fēng)  
MPEGTS.js是一個(gè)輕量級(jí)的JavaScript庫(kù),用于處理MPEG-TS流,這篇文章主要給大家介紹了關(guān)于vue使用mpegts.js的詳細(xì)步驟記錄,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

最簡(jiǎn)單好用的H265網(wǎng)頁(yè)播放器-mpegts.js

H265是新一代視頻編碼規(guī)范,與H264相比壓縮比更高,同樣的碼率下視頻質(zhì)量更高,或者說(shuō)同樣質(zhì)量的視頻占用的帶寬和存儲(chǔ)更少

簡(jiǎn)介

mpegts.js 是在 HTML5 上直接播放MPEG-TS/FLV流的播放器,針對(duì)低延遲直播優(yōu)化。mpegts.js 通過(guò)在 JavaScript 中漸進(jìn)化解析 MPEG2-TS 流并實(shí)時(shí)轉(zhuǎn)封裝為 ISO BMFF (Fragmented MP4),然后通過(guò) Media Source Extensions 接口把音視頻數(shù)據(jù)共給 HTML5 < video > 元素

特征

  • 支持H264和H265視頻格式
  • 列表支持FLV封裝的H.264/H.265 + AAC / MP3媒體內(nèi)容
  • 支持HTTP-FLV,WebSocket-FLV協(xié)議
  • 兼容Chrome, FireFox, Safari 10, IE11 和Edge
  • 支持瀏覽器硬加

受限性

由于實(shí)現(xiàn)原理是通過(guò)js對(duì)各種h265封裝進(jìn)行解封裝,最后封裝成統(tǒng)一的mp4格式供給video標(biāo)簽,本身并不做解碼,所以播放能力最終以來(lái)播放終端的軟硬件環(huán)境,如果設(shè)備或?yàn)g覽器本身不支持h265就無(wú)法正常播放,比如Win7系統(tǒng)和較早的手機(jī)通常都無(wú)法播放h265視頻。

使用步驟

安裝引入

npm install --save mpegts.js
import mpegts from 'mpegts.js';

HTML 中添加視頻標(biāo)簽

     <video
      ref="videoPlayer"
      muted="muted">
      </video>

video知識(shí)擴(kuò)展

為了改善用戶體驗(yàn),瀏覽器策略限制自動(dòng)播放需靜音,若設(shè)置直接打開(kāi)頁(yè)面就播放,會(huì)報(bào)錯(cuò),無(wú)法播放

Uncaught (in promise) DOMException: play() failed because the user didn't interact with the document first.

  • 但以下情況除外

  • 需求

頁(yè)面打開(kāi)的時(shí)候,視頻就自動(dòng)播放

  • 解決方案

我們可以根據(jù)第一條,如果視頻是靜音狀態(tài)下就可以自動(dòng)播放,所以在自動(dòng)播放的時(shí)候失敗的時(shí)候,選擇靜音播放,提示打開(kāi)聲音,用戶點(diǎn)擊,于是有了第二個(gè)條件,視頻就可以帶著聲音播放了。

<div class="box">
    <video
      ref="videoPlayer"
      muted="muted">
      </video>
    <div class="model">
      <button>開(kāi)始播放</button>
    </div>
  </div>
  
——————

const video = this.$refs.videoPlayer

const model = document.querySelector('.model')
const btn = document.querySelector('button')
// 第一種方法 引導(dǎo)用戶去與頁(yè)面交互實(shí)現(xiàn)播放
async function play() {
  try {
    await video.play();
    //使用await的原因是因?yàn)関ideo.play()方法返回的是一個(gè)Promise,所以在這里我們可以對(duì)他進(jìn)行一些處理
    model.style.display = 'none';
    btn.removeEventListener('click', play);
    // 如果他自動(dòng)播放了就隱藏按鈕,消除點(diǎn)擊事件
  } catch (err) {
    model.style.display = 'block';
    btn.addEventListener('click', play);
    // 如果Promise返回的是error就引導(dǎo)用戶點(diǎn)擊按鈕,在調(diào)用play方法
  }
}
play();

//第二種方法比較主流,類似的有網(wǎng)頁(yè)版抖音以及B站
function play() {
  video.muted = true;//設(shè)置視頻為靜音
  video.play();//調(diào)用播放方法
  const ctx = new AudioContext();
  const canAutoPlay = ctx.state === 'running'; //通過(guò)這個(gè)可以判斷出視頻能不能夠自動(dòng)播放 如何可以它的值就是“running” 否則為"suspended"
  // 如果是不能播放我們就執(zhí)行下面的邏輯,其實(shí)就是類似于第一種方法,讓用戶與其交互
  ctx.close();
  if (canAutoPlay) {
    video.muted = false;
    model.style.display = 'none';
    btn.removeEventListener('click', play);
  }
  else {
    model.style.display = 'block';
    btn.addEventListener('click', play);
  }
}
play()

在容器里創(chuàng)建播放器

    data() {
    return {
      player: null,
    };
   },

——————
   
    createPlayer(url) {
      if (mpegts.isSupported()) { //判斷瀏覽器是否支持播放
        if (this.player) {
          this.destory();
        }
        this.player = mpegts.createPlayer( //創(chuàng)建一個(gè)播放器實(shí)例
          {
            type: "flv",//播放的格式 flv mp4 ts mse等
            url,
            isLive: true, //指示數(shù)據(jù)源是否為直播流
            isAutoPlay: true,//是否自動(dòng)播放
            isContinue: true, //是否循環(huán)播放
            lazyLoad: true,//如果有足夠的數(shù)據(jù)進(jìn)行播放,則終止http連接
            hasAudio: false,//聲音關(guān)閉,如果傳來(lái)的視頻流沒(méi)有聲音,就一定要設(shè)置這個(gè)參數(shù),否則會(huì)報(bào)錯(cuò)
          },
          {
            enableWorker: true,//是否啟用分離線程
            enableStashBuffer: false,//是否關(guān)閉IO隱藏緩沖區(qū)
            stashInitialSize: 128,//IO存儲(chǔ)緩沖區(qū)初始大小,默認(rèn)為384kb
          }
        );

        this.player.attachMediaElement(this.$refs.videoPlayer); //將播放器注冊(cè)到Video節(jié)點(diǎn)
        this.player.load(); //加載
        setTimeout(() => {
          this.player
            .play()
            .then(() => {
              console.log("播放");
            })
            .catch((err) => {
              console.log("err", err);
            });
        });
      }
    },

    destory() {
      if (this.player) {
        try {
          this.player.pause(); //暫停播放
          this.player.unload();//取消數(shù)據(jù)流加載
          this.player.detachMediaElement();//將播放實(shí)例從節(jié)點(diǎn)中取出
          this.player.destroy(); //銷毀
          this.player = null;
        } catch (e) {
          // console.log(e);
        }
      }
    },

總結(jié) 

到此這篇關(guān)于vue使用mpegts.js的文章就介紹到這了,更多相關(guān)vue使用mpegts.js內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue實(shí)現(xiàn)表單單獨(dú)移除一個(gè)字段驗(yàn)證

    vue實(shí)現(xiàn)表單單獨(dú)移除一個(gè)字段驗(yàn)證

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)表單單獨(dú)移除一個(gè)字段驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 基于Vue實(shí)現(xiàn)tab欄切換內(nèi)容不斷實(shí)時(shí)刷新數(shù)據(jù)功能

    基于Vue實(shí)現(xiàn)tab欄切換內(nèi)容不斷實(shí)時(shí)刷新數(shù)據(jù)功能

    在項(xiàng)目開(kāi)發(fā)中遇到這樣需求,就是有幾個(gè)tab欄,每個(gè)tab欄對(duì)應(yīng)的ajax請(qǐng)求不一樣,內(nèi)容區(qū)域一樣,內(nèi)容為實(shí)時(shí)刷新數(shù)據(jù),實(shí)現(xiàn)方法其實(shí)很簡(jiǎn)單的,下面小編給大家?guī)?lái)了基于Vue實(shí)現(xiàn)tab欄切換內(nèi)容不斷實(shí)時(shí)刷新數(shù)據(jù)功能,需要的朋友參考下吧
    2017-04-04
  • vue如何清除瀏覽器歷史棧

    vue如何清除瀏覽器歷史棧

    這篇文章主要介紹了vue如何清除瀏覽器歷史棧,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue使用axios獲取不到響應(yīng)頭Content-Disposition的問(wèn)題及解決

    vue使用axios獲取不到響應(yīng)頭Content-Disposition的問(wèn)題及解決

    這篇文章主要介紹了vue使用axios獲取不到響應(yīng)頭Content-Disposition的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • vue中el-input綁定鍵盤按鍵(按鍵修飾符)

    vue中el-input綁定鍵盤按鍵(按鍵修飾符)

    這篇文章主要介紹了vue中el-input綁定鍵盤按鍵(按鍵修飾符),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 詳解vue 自定義組件使用v-model 及探究其中原理

    詳解vue 自定義組件使用v-model 及探究其中原理

    這篇文章主要介紹了詳解vue 自定義組件使用v-model 及探究其中原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 詳解Vue自定義過(guò)濾器的實(shí)現(xiàn)

    詳解Vue自定義過(guò)濾器的實(shí)現(xiàn)

    這篇文章主要介紹了詳解Vue自定義過(guò)濾器的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。
    2017-01-01
  • vue3中實(shí)現(xiàn)雙向數(shù)據(jù)綁定的方法

    vue3中實(shí)現(xiàn)雙向數(shù)據(jù)綁定的方法

    Vue3中,雙向數(shù)據(jù)綁定主要通過(guò)v-model指令實(shí)現(xiàn),v-model是一個(gè)語(yǔ)法糖,結(jié)合了v-bind和v-on指令來(lái)實(shí)現(xiàn)數(shù)據(jù)的雙向綁定,它在內(nèi)部做了綁定數(shù)據(jù)和監(jiān)聽(tīng)輸入事件兩件事,感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • vue實(shí)現(xiàn)同一個(gè)頁(yè)面可以有多個(gè)router-view的方法

    vue實(shí)現(xiàn)同一個(gè)頁(yè)面可以有多個(gè)router-view的方法

    今天小編就為大家分享一篇vue實(shí)現(xiàn)同一個(gè)頁(yè)面可以有多個(gè)router-view的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Vue點(diǎn)擊切換Class變化,實(shí)現(xiàn)Active當(dāng)前樣式操作

    Vue點(diǎn)擊切換Class變化,實(shí)現(xiàn)Active當(dāng)前樣式操作

    這篇文章主要介紹了Vue點(diǎn)擊切換Class變化,實(shí)現(xiàn)Active當(dāng)前樣式操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07

最新評(píng)論