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

vue使用mpegts.js的詳細步驟記錄

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

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

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

簡介

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

特征

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

受限性

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

使用步驟

安裝引入

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

HTML 中添加視頻標簽

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

video知識擴展

為了改善用戶體驗,瀏覽器策略限制自動播放需靜音,若設置直接打開頁面就播放,會報錯,無法播放

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

  • 但以下情況除外

  • 需求

頁面打開的時候,視頻就自動播放

  • 解決方案

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

<div class="box">
    <video
      ref="videoPlayer"
      muted="muted">
      </video>
    <div class="model">
      <button>開始播放</button>
    </div>
  </div>
  
——————

const video = this.$refs.videoPlayer

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

//第二種方法比較主流,類似的有網(wǎng)頁版抖音以及B站
function play() {
  video.muted = true;//設置視頻為靜音
  video.play();//調用播放方法
  const ctx = new AudioContext();
  const canAutoPlay = ctx.state === 'running'; //通過這個可以判斷出視頻能不能夠自動播放 如何可以它的值就是“running” 否則為"suspended"
  // 如果是不能播放我們就執(zhí)行下面的邏輯,其實就是類似于第一種方法,讓用戶與其交互
  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)建一個播放器實例
          {
            type: "flv",//播放的格式 flv mp4 ts mse等
            url,
            isLive: true, //指示數(shù)據(jù)源是否為直播流
            isAutoPlay: true,//是否自動播放
            isContinue: true, //是否循環(huán)播放
            lazyLoad: true,//如果有足夠的數(shù)據(jù)進行播放,則終止http連接
            hasAudio: false,//聲音關閉,如果傳來的視頻流沒有聲音,就一定要設置這個參數(shù),否則會報錯
          },
          {
            enableWorker: true,//是否啟用分離線程
            enableStashBuffer: false,//是否關閉IO隱藏緩沖區(qū)
            stashInitialSize: 128,//IO存儲緩沖區(qū)初始大小,默認為384kb
          }
        );

        this.player.attachMediaElement(this.$refs.videoPlayer); //將播放器注冊到Video節(jié)點
        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();//將播放實例從節(jié)點中取出
          this.player.destroy(); //銷毀
          this.player = null;
        } catch (e) {
          // console.log(e);
        }
      }
    },

總結 

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

相關文章

  • axios庫的核心代碼解析及總結

    axios庫的核心代碼解析及總結

    這篇博客針對axios庫的核心代碼做一個簡要總結,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue踩坑記之npm?install報錯問題解決總結

    vue踩坑記之npm?install報錯問題解決總結

    當你跑起一個項目的時候,第一步需要先安裝依賴npm install,下面這篇文章主要給大家介紹了關于vue踩坑之npm?install報錯問題解決的相關資料,需要的朋友可以參考下
    2022-06-06
  • Vue常用的幾個指令附完整案例

    Vue常用的幾個指令附完整案例

    越來越多的人在用Vue,剛開始接觸vue的話常接觸的指令就幾個,統(tǒng)一歸納一下。感興趣的朋友跟隨小編一起看看吧
    2018-11-11
  • Vue2和Vue3如何使用watch偵聽器詳解

    Vue2和Vue3如何使用watch偵聽器詳解

    這篇文章主要介紹了在Vue2和Vue3中如何使用watch偵聽器,分別對vue2及vue3作了詳細的說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • vue+iview框架實現(xiàn)左側動態(tài)菜單功能的示例代碼

    vue+iview框架實現(xiàn)左側動態(tài)菜單功能的示例代碼

    這篇文章主要介紹了vue+iview框架實現(xiàn)左側動態(tài)菜單功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Vue遞歸實現(xiàn)樹形菜單方法實例

    Vue遞歸實現(xiàn)樹形菜單方法實例

    學習vue有一段時間了,最近使用vue做了一套后臺管理系統(tǒng),其中使用最多就是遞歸組件,下面這篇文章主要給大家介紹了關于Vue利用遞歸實現(xiàn)樹形菜單的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2018-11-11
  • vue使用video插件vue-video-player的示例

    vue使用video插件vue-video-player的示例

    這篇文章主要介紹了vue使用video插件vue-video-player的示例,幫助大家更好的理解和使用vue插件,感興趣的朋友可以了解下
    2020-10-10
  • 在vue中使用echarts實現(xiàn)上浮與下鉆效果

    在vue中使用echarts實現(xiàn)上浮與下鉆效果

    這篇文章主要介紹了在vue中使用echarts實現(xiàn)上浮與下鉆效果,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-11-11
  • vite項目配置less全局樣式的實現(xiàn)步驟

    vite項目配置less全局樣式的實現(xiàn)步驟

    最近想實現(xiàn)個項目,需要配置全局less,本文主要介紹了vite項目配置less全局樣式的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2024-02-02
  • Vue2.0 $set()的正確使用詳解

    Vue2.0 $set()的正確使用詳解

    這篇文章主要介紹了Vue2.0 $set()的正確使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07

最新評論