vue常用插件之視頻播放(rtmp m3u8)

来源:https://www.cnblogs.com/sgs123/archive/2020/01/15/12197635.html
-Advertisement-
Play Games

vue video player(5.0.2) 最近我的項目做了一個監控視屏的顯示,後臺提供的視屏格式是rtmp 後來又改為m3u8,沒成功,原因是占用記憶體過大,所以取消了這種方式 一、安裝 npm i vue video player S npm i videojs flash S lxx___播 ...


vue-video-player(5.0.2)

最近我的項目做了一個監控視屏的顯示,後臺提供的視屏格式是rtmp
後來又改為m3u8,沒成功,原因是占用記憶體過大,所以取消了這種方式

一、安裝

npm i vue-video-player -S
npm i videojs-flash -S ______播放rtmp
npm i videojs-contrib-hls -S ______播放m3u8

二、全局引入(main.js)

import VideoPlayer from 'vue-video-player'
import 'video.js/dist/video-js.css' //videoJs的樣式
// import 'vue-video-player/src/custom-theme.css' //vue-video-player的樣式
import 'videojs-flash'; //引入才能播放rtmp視屏
// import 'videojs-contrib-hls' //引入才能播放m3u8文件
Vue.use(VideoPlayer)

三、在頁面中使用

<video-player  class="video-player vjs-custom-skin"
  ref="videoPlayer" 
  :playsinline="true" 
  :options="playerOptions"
  @play="onPlayerPlay($event)"
  @pause="onPlayerPause($event)"
  @ended="onPlayerEnded($event)"
></video-player>
//完整的配置數據(不要的可以直接註釋掉)
data(){
  return {
    playerOptions:{
      playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
      autoplay: false, //如果true,瀏覽器準備好時開始回放。
      muted: false, // 預設情況下將會消除任何音頻。
      loop: false, // 導致視頻一結束就重新開始。
      preload: 'auto', // 建議瀏覽器在<video>載入元素後是否應該開始下載視頻數據。auto瀏覽器選擇最佳行為,立即開始載入視頻(如果瀏覽器支持)
      language: 'zh-CN',
      aspectRatio: '16:9', // 將播放器置於流暢模式,併在計算播放器的動態大小時使用該值。值應該代表一個比例 - 用冒號分隔的兩個數字(例如"16:9"或"4:3")
      // fluid: true, // 當true時,Video.js player將擁有流體大小。換句話說,它將按比例縮放以適應其容器。
      sources: [{
        type: "application/x-mpegURL",//這裡的種類支持很多種:基本視頻格式、直播、流媒體等,具體可以參看git網址項目
        src: "" //url地址
      }],
      // hls:true, //如果是播放m3u8必須加(需註釋掉techOrder,不然會有報錯)
      techOrder: ['flash'], //播放rtmp必須加
      poster: "", //你的封面地址
      notSupportedMessage: '此視頻暫無法播放,請稍後再試', //允許覆蓋Video.js無法播放媒體源時顯示的預設信息。
      controlBar: {
        timeDivider: true,
        durationDisplay: true,
        remainingTimeDisplay: false,
        fullscreenToggle: true  //全屏按鈕
      }
    }
  }
}

四、使用過程中遇到的問題

1、設置了autoplay: true 不能自動播放,原因是我這裡播放視頻的視窗小於了400x400
2、如何使用外部按鈕點擊全屏

//點擊全屏播放
handleFullScreen(index){
  const player = this.$refs.videoPlayer.player;
  player.requestFullscreen();//調用全屏api方法
  player.isFullscreen(true)
  player.play()
}

用來測試的流

香港財經:rtmp://202.69.69.180:443/webcast/bshdlive-pc
芒果TV:rtmp://58.200.131.2:1935/livetv/hunantv
南韓GoodTV:rtmp://mobliestream.c3tv.com:554/live/goodtv.sdp


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是移動App開發【重點】 1. 蘋果上的軟體是如何開發出來的:使用IOS平臺的開發工具和開發語言進行設計開發的!蘋果上的開發語言:OC、Swift 2. 安卓平臺上的軟體又是如何開發出來的:使用Java這麼語言,結合一些Android控制項,就可以開發安卓上的手機軟體; 3. 蘋果和安卓平臺上共有 ...
  • Android項目用Gradle構建, 其腳本語言之前是Groovy, 目前也提供了Kotlin的支持, 所以可以遷移到Kotlin. 官方的遷移文檔說明的是更通用的步驟. 本文通過一個具體的Android項目來舉例如何遷移, 文後附有sample. ...
  • Plugin(插件) 是 webpack 生態的的一個關鍵部分。它為社區提供了一種強大的方法來擴展 webpack 和開發 webpack 的編譯過程。這篇文章將嘗試探索 webpack plugin,揭秘它的工作原理,以及如何開發一個 plugin。 ...
  • jquery: 簡單、粗暴 jq和js的關係 js是什麼? js是一門編程語言 jq僅僅是基於js的一個庫,jq可理解為就是開發js的一個工具。 概念 1. 為什麼要學jquery ? 簡單,粗暴 沒有相容性問題 2. 什麼是jquery?js庫,說白了就是js文件,裡面有一大堆的方法 3. 使用j ...
  • 淘寶精品案例 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { margin: 0; padding: 0; font-size: 12 ...
  • 手風琴案例 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { padding: 0; margin: 0; } ul { list-st ...
  • 突出展示案例 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { margin: 0; padding: 0; } ul { list-s ...
  • HTML代碼: <!DOCTYPE html> <html> <head> <title>Vue Demo</title> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta nam ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...