校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > HTML5 播放 RTSP 視頻的實例代碼

HTML5 播放 RTSP 視頻的實例代碼

熱門標(biāo)簽:電話機(jī)器人技術(shù) 智能電銷機(jī)器人被禁用了么 如何查看地圖標(biāo)注 地圖標(biāo)注軟件打印出來 欣鼎電銷機(jī)器人 效果 ok電銷機(jī)器人 黃石ai電銷機(jī)器人呼叫中心 惡搞電話機(jī)器人 高德地圖標(biāo)注商戶怎么標(biāo)

目前大多數(shù)網(wǎng)絡(luò)攝像頭都是通過 RTSP 協(xié)議傳輸視頻流的,但是 HTML 并不標(biāo)準(zhǔn)支持 RTSP 流。除了 Firefox 瀏覽器可以直接播放 RTSP 流之外,幾乎沒有其他瀏覽器可以直接播放 RTSP 流。Electron 應(yīng)用是基于 Chromium 內(nèi)核的,因此也不能直接播放 RTSP 流。

在借助一定工具的情況下,可以實現(xiàn)在 Web 頁面上播放 RTSP 流。本文介紹的方法可以應(yīng)用于傳統(tǒng) Web 應(yīng)用和 Electron 應(yīng)用中,唯一的區(qū)別是將 Electron 應(yīng)用的主進(jìn)程當(dāng)作傳統(tǒng) Web 應(yīng)用的服務(wù)器。

目前已有 RTSP 播放方案的對比

既然是做直播,就需要延遲較低。當(dāng)攝像頭掉線時,也應(yīng)當(dāng)有一定的事件提示。處于這兩點,對目前已有的已經(jīng)實現(xiàn)、無需購買許可證的 RTSP 播放方案進(jìn)行對比(處于原理階段的暫時不分析)。

我對這四種方式都進(jìn)行了實現(xiàn),整體效果最好的還是第4種方案,占用端口少,延遲低,渲染速度快,而且離線事件易于處理。

基于 flv.js 的 RTSP 播放方案

flv.js 是 Bilibili 開源的一款 HTML5 瀏覽器。依賴于 Media Source Extension 進(jìn)行視頻播放,視頻通過 HTTP-FLV 或 WebSocket-FLV 協(xié)議傳輸,視頻格式需要為 FLV 格式。

服務(wù)器端(主進(jìn)程)

服務(wù)器端采用 express + express-ws 框架進(jìn)行編寫,當(dāng)有 HTTP 請求發(fā)送到指定的地址時,啟動 ffmpeg 串流程序,直接將 RTSP 流封裝成 FLV 格式的視頻流,推送到指定的 WebSocket 響應(yīng)流中。

import * as express from "express";
import * as expressWebSocket from "express-ws";
import ffmpeg from "fluent-ffmpeg";
import webSocketStream from "websocket-stream/stream";
import WebSocket from "websocket-stream";
import * as http from "http";
function localServer() {
    let app = express();
    app.use(express.static(__dirname));
    expressWebSocket(app, null, {
        perMessageDeflate: true
    });
    app.ws("/rtsp/:id/", rtspRequestHandle)
    app.listen(8888);
    console.log("express listened")
}
function rtspRequestHandle(ws, req) {
    console.log("rtsp request handle");
    const stream = webSocketStream(ws, {
        binary: true,
        browserBufferTimeout: 1000000
    }, {
        browserBufferTimeout: 1000000
    });
    let url = req.query.url;
    console.log("rtsp url:", url);
    console.log("rtsp params:", req.params);
    try {
        ffmpeg(url)
            .addInputOption("-rtsp_transport", "tcp", "-buffer_size", "102400")  // 這里可以添加一些 RTSP 優(yōu)化的參數(shù)
            .on("start", function () {
                console.log(url, "Stream started.");
            })
            .on("codecData", function () {
                console.log(url, "Stream codecData.")
             // 攝像機(jī)在線處理
            })
            .on("error", function (err) {
                console.log(url, "An error occured: ", err.message);
            })
            .on("end", function () {
                console.log(url, "Stream end!");
             // 攝像機(jī)斷線的處理
            })
            .outputFormat("flv").videoCodec("copy").noAudio().pipe(stream);
    } catch (error) {
        console.log(error);
    }
}

為了實現(xiàn)較低的加載時間,可以為 ffmpeg 添加如下參數(shù):

  • analyzeduration 可以降低解析碼流所需要的時間
  • max_delay 資料上寫的具體作用不太記得了,效果沒有 analyzeduration 明顯

當(dāng)然這個實現(xiàn)還比較粗糙。當(dāng)有多個相同地址的請求時,應(yīng)當(dāng)增加 ffmpeg 的輸出,而不是啟動一個新的 ffmpeg 進(jìn)程串流。

瀏覽器端(渲染進(jìn)程)

示例使用 Vue 框架進(jìn)行頁面設(shè)計。

<template>
    <div>
        <video class="demo-video" ref="player"></video>
    </div>
</template>
<script>
import flvjs from "flv.js";
export default {
    props: {
        rtsp: String,
        id: String
    },
    /**
     * @returns {{player: flvjs.Player}}
     */
    data () {
        return {
            player: null
        }
    },
    mounted () {
        if (flvjs.isSupported()) {
            let video = this.$refs.player;
            if (video) {
                this.player = flvjs.createPlayer({
                    type: "flv",
                    isLive: true,
                    url: `ws://localhost:8888/rtsp/${this.id}/?url=${this.rtsp}`
                });
                this.player.attachMediaElement(video);
                try {
                    this.player.load();
                    this.player.play();
                } catch (error) {
                    console.log(error);
                };
            }
        }
    },
    beforeDestroy () {
        this.player.destory();
    }
}
</script>
<style>
    .demo-video {
        max-width: 480px; 
        max-height: 360px;
    }
</style>

效果展示

用 Electron 頁面展示了 7 個 Hikvison NVR 的攝像頭,可以實現(xiàn)低延遲,低 CPU 占用,無花屏現(xiàn)象。由于涉及保密,這里就不放截圖了。

同樣的方法我播放了 9 個本地 1080p 的視頻《白鹿原》,可以看一下這個效果。

播放效果非常好,完全沒有卡頓和花屏,CPU 占用率也不高。

示例代碼倉庫: WhuRS-FGis/html5-rtsp 示例代碼倉庫:

總結(jié)

以上所述是小編給大家介紹的HTML5 播放 RTSP 視頻的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

標(biāo)簽:中山 盤錦 阿壩 聊城 綏化 金昌 赤峰 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5 播放 RTSP 視頻的實例代碼》,本文關(guān)鍵詞  HTML5,播放,RTSP,視頻,的,實例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5 播放 RTSP 視頻的實例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5 播放 RTSP 視頻的實例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 丹东市| 讷河市| 鹿泉市| 永济市| 龙山县| 梁山县| 和硕县| 阳信县| 洞口县| 安多县| 吉木萨尔县| 余干县| 滨州市| 上杭县| 宜宾市| 凤台县| 偏关县| 霍林郭勒市| 靖州| 林芝县| 罗山县| 杭锦后旗| 墨玉县| 依兰县| 五家渠市| 济宁市| 长顺县| 泽州县| 巴林左旗| 乡宁县| 济源市| 通州区| 秦安县| 临汾市| 铜川市| 高阳县| 庆阳市| 黎城县| 永丰县| 平泉县| 安化县|