【使用webrtc-streamer解析rtsp視頻流】

webrtc-streamer

  • WebRTC (Web Real-Time Communications) 是一項實時通訊技術,它允許網絡應用或者站點,在不借助中間媒介的情況下,建立瀏覽器之間點對點(Peer-to-Peer)的連接,實現視頻流和(或)音頻流或者其他任意數據的傳輸。WebRTC 包含的這些標準使用戶在無需安裝任何插件或者第三方的軟件的情況下,創建點對點(Peer-to-Peer)的數據分享和電話會議成為可能。

    簡單的說:WebRTC 是一種 HTML5規范,他無需在瀏覽器中安裝任何插件可以在網頁內進行實時通信工作的開源技術,它直接在瀏覽器和設備之間添加實時媒體通信。
    
  • rtsp(Real Time Streaming Protocol,RTSP)是實時視頻網絡傳輸主流的實現方式,是一種網絡流媒體協議。低延時高清晰度的RTSP視頻流傳輸是網絡直播、在線會議系統等行業的核心技術。

  • webrtc-streamer是一個使用簡單機制通過 WebRTC 流式傳輸視頻捕獲設備和 RTSP 源的項目,它內置了一個小型的 HTTP server 來對 WebRTC需要的相關接口提供支持。

使用方法

1、下載webrtc-streamer

https://github.com/mpromonet/webrtc-streamer/releases

2、運行

雙擊解壓后的.exe文件運行,默認拋出本機8000端口(172.0.0.1:8000)
  • 由于 webrtc 的核心庫還不支持H265的視頻編碼,所以要配置設備視頻編碼方式為H264
  • 命令:-o ,默認情況video會進行編碼、解碼,占用資源,可能導致cpu拉滿,使用-o將取消編碼解碼
  • 自定義端口:創建.bat文件,并雙擊執行,文件內容如下:
    @echo off
    start "" ".\webrtc-streamer.exe"  -H 0.0.0.0:9998 -o
    exit
    
  • 運行成功后,可在瀏覽器中查詢所有api
    //192.168.3.33:9998/api/help
    http: ['/api/addIceCandidate','/api/call','/api/createOffer','/api/getAudioDeviceList','/api/getAudioPlayoutList','/api/getIceCandidate','/api/getIceServers','/api/getMediaList','/api/getPeerConnectionList', // 判斷當前的webrtc-streamer正在連接的通道'/api/getStreamList','/api/getVideoDeviceList','/api/hangup','/api/help','/api/log','/api/setAnswer','/api/version','/api/whep'
    ]
    

3、引用開發包

  • 將下載包html文件夾下webrtcstreamer.js文件和html/libs文件夾下adapter.min.js文件復制到VUE項目public目錄下 、在index.html文件里引入這兩個js文件
    <head><!-- rtsp --><script src="/data/webrtcstreamer.js" charset="utf-8"></script><script src="/data/adapter.min.js" charset="utf-8"></script>
    </head>
    

4、頁面中使用

<template><div class="ev-player"><CommonDragWindow v-model="innerShow" :width="600" :height="400" :resize="true" :position="position"><template v-slot:title>{{ title }}</template><template #default><video :id="`video-${equipId}`" autoplay width="100%" height="98%"></video></template></CommonDragWindow></div>
</template><script setup>import CommonDragWindow from './CommonDragWindow.vue'import { getConfigList } from '@/api/common.js'import { ref, onMounted, watchEffect, watch, nextTick } from 'vue'const show = defineModel({ type: Boolean, default: false })const props = defineProps({title: {type: String,default: '監控視頻'},equipId: {type: [Number, String]}})const innerShow = ref(false)const position = ref({top: 500,left: 20})let webRtcServer = nullwatchEffect(() => {innerShow.value = show.value})watch(() => innerShow.value,async (val) => {if (val) {const rtspStr = 'rtsp://132.239.12.145:554/axis-media/media.amp'if (rtspStr) {await nextTick() // 待dom加載完畢let videoDocument = document.getElementById('video')webRtcServer = new WebRtcStreamer(videoDocument, `http://${window.appConfig.localhost}:8000`)webRtcServer.connect(rtspStr, null, `rtptransport=tcp&timeout=60`)}} else {webRtcServer?.disconnect()webRtcServer = null}show.value = val})onMounted(() => {})
</script><style scoped lang="scss">.ev-player {:deep(video) {width: 100%;height: calc(100% - 5px);}}
</style>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/37410.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/37410.shtml
英文地址,請注明出處:http://en.pswp.cn/web/37410.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

了解 ZooKeeper:關鍵概念和架構

ZooKeeper 是一種分布式協調服務&#xff0c;廣泛用于分布式系統中&#xff0c;用于維護配置信息、命名、同步和組服務。它最初由雅虎開發&#xff0c;現在是一個 Apache 項目&#xff0c;已成為許多大型分布式應用程序不可或缺的一部分。本文深入探討 ZooKeeper 的關鍵概念和架…

【Android】Activity子類之間的區別

從底層往頂層的繼承順序依次是&#xff1a; Activity&#xff0c;最原始的Activity androidx.core.app.ComponentActivity&#xff0c;僅僅優化了一個關于KeyEvent的攔截問題&#xff0c;一般不繼承這個類 androidx.activity.ComponentActivity&#xff0c;支持和Android Arc…

Spark Join優化案例:Join Key 遠大于 Payload

在一個案例中&#xff0c;大表 100GB、小表 10GB&#xff0c;它們全都遠超廣播變量閾值&#xff08;默認 10MB&#xff09;。因為小表的尺寸已經超過 8GB&#xff0c;在大于 8GB 的數據集上創建廣播變量&#xff0c;Spark 會直接拋出異常&#xff0c;中斷任務執行&#xff0c;所…

C語言 求 n 個數的階乘之和

求n個數的階乘之和&#xff08;即求1&#xff01;2&#xff01;3&#xff01;…n!&#xff09; 這個程序讀取用戶輸入的正整數 n&#xff0c;計算并輸出 1! 2! 3! ... n! 的值。 #include <stdio.h>// 計算階乘的函數 long factorial(int num) {long result 1;for…

恢復 IntelliJ IDEA 中消失的菜單欄

要恢復 IntelliJ IDEA 中消失的菜單欄&#xff0c;可以按照以下簡單步驟操作&#xff1a; 使用快捷鍵打開搜索&#xff1a;首先&#xff0c;雙擊 Shift 鍵打開全局搜索對話框。 搜索“Menu”&#xff1a;在搜索框中輸入 menu&#xff0c;然后從搜索結果中選擇與“Main Menu”相…

python-基礎篇-選擇-是什么

文章目錄 定義一&#xff1a;Python 條件語句跟其他語言基本一致的&#xff0c;都是通過一條或多條語句的執行結果&#xff08; True 或者 False &#xff09;來決定執行的代碼塊。1、什么是條件語句2、if 語句的基本形式3、if 語句多個判斷條件的形式4、if 語句多個條件同時判…

次序統計量

內容來源 概率論與數理統計教程&#xff08;第三版&#xff09; 茆詩松 高等教育出版社 數理統計學導論&#xff08;原書第7版&#xff09; 機械工業出版社 定義 設 X 1 , X 2 , ? , X n X_1,X_2,\cdots,X_n X1?,X2?,?,Xn? 是來自連續分布的隨機樣本 此分布具有 p d f…

【機器學習】Python reversed 函數

目錄&#xff1a; reversed()函數初探應用于列表和元組實戰演練&#xff1a;山海經故事文本處理 Python中的內置函數——reversed()。 這個函數能夠幫助你高效地處理序列類型數據&#xff0c;比如列表、元組、字符串等&#xff0c;通過它你可以輕松地反轉這些序列中的元素順…

JSON 簡述與應用

1. JSON 簡述 JSON&#xff08;JavaScript Object Notation&#xff09;是一種輕量級的數據交換格式&#xff0c;常用于客戶端與服務器之間的數據傳遞。它基于JavaScript對象表示法&#xff0c;但獨立于語言&#xff0c;可以被多種編程語言解析和生成。 1.1 特點 輕量級&#…

JS對數據類型的檢測方式

1. typeof()對于基本數據類型沒問題&#xff0c;遇到引用數據類型就不管用 console.log( typeof 666 ); // number console.log( typeof [1,2,3] ); // object 2. instanceof()只能判斷引用數據類型&#xff0c;不能判斷基本數據類型 console.log( [] instanceof Array ) // tr…

Unity--協程--Coroutine

Unity–協程–Coroutine 1. 協程的基本概念 基本概念:不是線程,將代碼按照劃分的時間來執行,這個時間可以是具體的多少秒,也可以是物理幀的時間,也可以是一幀的繪制結束的時間。 協程的寫法&#xff1a;通過返回IEnumerator的函數實現&#xff0c;使用yield return語句暫停執…

Golang | Leetcode Golang題解之第205題同構字符串

題目&#xff1a; 題解&#xff1a; func isIsomorphic(s, t string) bool {s2t : map[byte]byte{}t2s : map[byte]byte{}for i : range s {x, y : s[i], t[i]if s2t[x] > 0 && s2t[x] ! y || t2s[y] > 0 && t2s[y] ! x {return false}s2t[x] yt2s[y] …

python 查找輪廓

在Python中&#xff0c;查找圖像的輪廓通常使用OpenCV庫。以下是一個簡單的示例代碼&#xff0c;展示了如何使用OpenCV來查找并繪制圖像的輪廓&#xff1a; pythonimport cv2 import numpy as np# 讀取圖像 image cv2.imread(your_image.jpg, 0) # 請將your_image.jpg替換為您…

設備樹下的 platform 驅動編寫

設備樹下的 platform 驅動編寫 設備樹下的 platform 驅動簡介 platform 驅動框架分為總線、設備和驅動&#xff0c;其中總線不需要我們這些驅動程序員去管理&#xff0c;這個是 Linux 內核提供的&#xff0c;我們在編寫驅動的時候只要關注于設備和驅動的具體實現即可。在沒有…

《昇思25天學習打卡營第6天 | 函數式自動微分》

《昇思25天學習打卡營第6天 | 函數式自動微分》 目錄 《昇思25天學習打卡營第6天 | 函數式自動微分》函數式自動微分簡單的單層線性變換模型函數與計算圖微分函數與梯度計算Stop Gradient 函數式自動微分 神經網絡的訓練主要使用反向傳播算法&#xff0c;模型預測值&#xff0…

建站小記:遷移域名DNS到CloudFlare

CloudFlare一直有賽博菩薩之稱&#xff0c;據說用它做DNS解析服務又快又好又免費&#xff0c;還能防DDOS攻擊&#xff0c;并且可以提供頁面訪問統計功能。 正好我博客網頁打開略卡頓&#xff0c;所以決定將自己的DNS解析遷移到CloudFlare。 1.登錄CF控制臺&#xff0c;添加自己…

LeetCode-刷題記錄-二分法合集(本篇blog會持續更新哦~)

一、二分查找概述 二分查找&#xff08;Binary Search&#xff09;是一種高效的查找算法&#xff0c;適用于有序數組或列表。&#xff08;但其實只要滿足二段性&#xff0c;就可以使用二分法&#xff0c;本篇博客后面博主會持續更新一些題&#xff0c;來破除一下人們對“只有有…

(已解決)Adobe Flash Player已不再受支持

文章目錄 前言解決方案 前言 一般來說&#xff0c;很少遇到官方網站使用Adobe Flash Player來進行錄用名單公示了。但是&#xff0c;今天就偏偏遇到一次&#xff0c; 用谷歌瀏覽器打不開&#xff0c; 點了沒有反應&#xff0c;用其他的瀏覽器&#xff0c;例如windows自帶的那…

Golang | Leetcode Golang題解之第207題課程表

題目&#xff1a; 題解&#xff1a; func canFinish(numCourses int, prerequisites [][]int) bool {var (edges make([][]int, numCourses)indeg make([]int, numCourses)result []int)for _, info : range prerequisites {edges[info[1]] append(edges[info[1]], info[0]…

數據結構:期末考 第六次測試(總復習)

一、 單選題 &#xff08;共50題&#xff0c;100分&#xff09; 1、表長為n的順序存儲的線性表&#xff0c;當在任何位置上插入或刪除一個元素的概率相等時&#xff0c;插入一個元素所需移動元素的平均個數為&#xff08; D &#xff09;.&#xff08;2.0&#xff09; A、 &am…