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

HTML5 播放 RTSP 視頻的實(shí)例代碼

  發(fā)布時(shí)間:2019-07-29 14:15:05   作者:佚名   我要評(píng)論
目前大多數(shù)網(wǎng)絡(luò)攝像頭都是通過(guò) RTSP 協(xié)議傳輸視頻流的,但是 HTML 并不標(biāo)準(zhǔn)支持 RTSP 流。本文重點(diǎn)給大家介紹HTML5 播放 RTSP 視頻的實(shí)例代碼,需要的朋友參考下吧

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

在借助一定工具的情況下,可以實(shí)現(xiàn)在 Web 頁(yè)面上播放 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 播放方案的對(duì)比

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

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

基于 flv.js 的 RTSP 播放方案

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

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

服務(wù)器端采用 express + express-ws 框架進(jìn)行編寫,當(dāng)有 HTTP 請(qǐng)求發(fā)送到指定的地址時(shí),啟動(dòng) 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);
    }
}

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

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

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

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

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

<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 頁(yè)面展示了 7 個(gè) Hikvison NVR 的攝像頭,可以實(shí)現(xiàn)低延遲,低 CPU 占用,無(wú)花屏現(xiàn)象。由于涉及保密,這里就不放截圖了。

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

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

示例代碼倉(cāng)庫(kù): WhuRS-FGis/html5-rtsp 示例代碼倉(cāng)庫(kù):

總結(jié)

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

相關(guān)文章

  • Html5 video 標(biāo)簽 src 用數(shù)據(jù)流方式播放視頻

    HTML5中的video標(biāo)簽用于播放視頻文件的,本文介紹了Html5 video 標(biāo)簽 src 用數(shù)據(jù)流方式播放視頻,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-27
  • HTML中實(shí)現(xiàn)音樂(lè)或視頻自動(dòng)播放案例詳解

    由于期末大作業(yè)我想插入一個(gè)背景音樂(lè),實(shí)現(xiàn)點(diǎn)開(kāi)網(wǎng)頁(yè)就會(huì)自動(dòng)播放音頻的效果,今天通過(guò)本文給大家分享下我基于HTML實(shí)現(xiàn)音樂(lè)或視頻自動(dòng)播放功能,代碼簡(jiǎn)單易懂,需要的朋友參
    2022-05-27
  • HTML5 video循環(huán)播放多個(gè)視頻的方法步驟

    這篇文章主要介紹了HTML5 video循環(huán)播放多個(gè)視頻的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)
    2020-08-06
  • html5中嵌入視頻自動(dòng)播放的問(wèn)題解決

    這篇文章主要介紹了html5中嵌入視頻自動(dòng)播放的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起
    2020-05-25
  • html5自動(dòng)播放mov格式視頻的實(shí)例代碼

    這篇文章主要介紹了html5自動(dòng)播放mov格式視頻的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-14
  • HTML5自定義視頻播放器源碼

    這篇文章主要介紹了HTML5自定義視頻播放器源碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-06
  • HTML5 視頻播放(video),JavaScript控制視頻的實(shí)例代碼

    這篇文章主要介紹了HTML5 視頻播放(video),JavaScript控制視頻的實(shí)例代碼,需要的朋友參考下吧
    2018-10-08
  • HTML5視頻播放插件 video.js介紹

    這篇文章主要介紹了HTML5視頻播放插件 video.js介紹 ,需要的朋友可以參考下
    2018-09-29
  • html5 視頻播放解決方案

    這里主要研究的是通過(guò)應(yīng)用html5來(lái)解決視頻播放的問(wèn)題。Adobe公司因?yàn)閼?zhàn)略錯(cuò)誤,忽視了移動(dòng)互聯(lián)這塊,移動(dòng)終端對(duì)flash支持并不好,特別是蘋果終端都不支持flash(蘋果電腦和
    2016-11-06
  • html網(wǎng)頁(yè)播放多個(gè)視頻的幾種方法

    本文主要介紹了html網(wǎng)頁(yè)播放多個(gè)視頻的幾種方法,包含iframe標(biāo)簽,VLC插件和一些常見(jiàn)的js插件,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-04

最新評(píng)論