vue2 中web端播放rtsp视频流 通过ffmpeg(海康威视录像机)

46 篇文章 2 订阅
6 篇文章 1 订阅


注意:这个方法实现了本地rtsp视频的播放,暂时没考虑服务器部署

参考文章:vue中web端播放rtsp视频流(摄像头监控视频)(海康威视录像机)

一、安装ffmpeg

ffmpeg下载:FFMpeg

找到左下角的Windows builds from gyan.dev下的Windows builds from gyan.dev

在这里插入图片描述

新页面找到ffmpeg-release-essentials.zip,点击下载,下载完解压

在这里插入图片描述

在这里插入图片描述

二、配置系统ffmpeg环境变量

1.点击环境变量

在这里插入图片描述

2.找到并点击Path,然后点击编辑

在这里插入图片描述

3.点击浏览,找到刚刚解压的目录

在这里插入图片描述

4.最好重启一下电脑,添加成功后验证是否生效任意地方打开cmd窗口输入 ffmpeg 打印如下表示成功

在这里插入图片描述

三、node搭建websocket服务

1.系统根目录新建一个app.js文件

在这里插入图片描述

app.js内容

const stream = require('node-rtsp-stream')
const urls = [
    'rtsp://admin:123456@192.168.2.100:554/Streaming/Channels/101',
    'rtsp://admin:123456@192.168.2.100:554/Streaming/Channels/201',
    'rtsp://admin:123456@192.168.2.100:554/Streaming/Channels/301'
]; // 将此处替换为实际的RTSP流地址
let wsPort = 9999; // 初始端口号
urls.forEach((url) => {
    new stream({
        name: `video-stream-${urls.indexOf(url) + 1}`,
        streamUrl: url,
        wsPort: wsPort,
        ffmpegOptions: {
            '-stats': '',
            '-r': 30,
            '-s': '1920*1080'
        }
    });
    wsPort++; // 每次递增端口号
});

2.下载安装node-rtsp-stream:

npm install node-rtsp-stream -S

3.运行

node app.js

出现下面界面就是成功了

在这里插入图片描述

四、vue播放视频

1.下载下来解压后放到public下面

jsmpeg.min.js下载地址:jsmpeg.min.js 蓝奏云

2.vue单文件

<template>
    <div class="view">
        <p>录像画面</p>
        <div id="video-container">
        </div>
    </div>
</template>
 
<script>
import '../../public/jsmpeg.min.js'
export default {
 
    data() {
        return {
            players: []
        };
    },
    methods: {
    },
    mounted() {
        //开始播放
        const container = document.getElementById('video-container');
        for (let i = 0; i < 3; i++) {
            const canvas = document.createElement('canvas');
            canvas.id = `video-${i + 1}`;
            canvas.style.width = '210px'; // 设置宽度为200px
            canvas.style.height = '210px'; // 设置高度为200px
            canvas.style.margin = '3px'; // 设置高度为200px
            container.appendChild(canvas);
            const url = `ws://127.0.0.1:${9999 + i}/video-stream-${i + 1}`;
            // const url = `ws://127.0.0.1:9999/video-stream-${i + 1}`;
            this.players.push(new JSMpeg.Player(url, { canvas }));
            this.players[i].play();
        }
 
    },
    watch: {},
    filters: {},
    beforeDestroy() {
        this.players.forEach(player => player.stop());
    }
 
}
 
</script>
<style scoped>
.view {
    background-color: rgb(43, 168, 188);
    box-sizing: border-box;
    
}
 
#video-container{
    height: 450px;
 
}
</style>

注意:jsmpeg.min.js建议在index.html引入,我只是不放心又引入了一遍,正常在index.html也要引入

后续在服务器上采用该方法的话会继续更新文章

下班~

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
对不起,`vue-video-player`插件并不支持直接播放RTSP视频流。这个插件主要用于播放常见的视频格式,如MP4、WebM和HLS等。如果你需要在Vue播放RTSP视频流,你可能需要使用其他的解决方案。 一种可能的解决方案是使用`hls.js`库来转换RTSP为HLS,然后再使用`vue-video-player`插件来播放HLS。下面是一个简单的示例: 首先,安装所需的依赖: ``` npm install video.js vue-video-player hls.js ``` 然后,在你的Vue组件使用这些库: ```vue <template> <div> <video-player ref="videoPlayer" :options="playerOptions" @ready="onPlayerReady"></video-player> </div> </template> <script> import 'video.js/dist/video-js.css' import 'vue-video-player/src/custom-theme.css' import VideoPlayer from 'vue-video-player' import Hls from 'hls.js' export default { components: { VideoPlayer }, data() { return { playerOptions: { autoplay: true, controls: true, sources: [{ type: 'application/x-mpegURL', src: 'YOUR_HLS_URL' }] } } }, mounted() { if (Hls.isSupported()) { const video = this.$refs.videoPlayer.$refs.video const hls = new Hls() hls.loadSource('YOUR_RTSP_TO_HLS_URL') hls.attachMedia(video) } }, methods: { onPlayerReady(player) { // player is ready } } } </script> ``` 在上述示例,你需要将`YOUR_RTSP_TO_HLS_URL`替换为将RTSP转换为HLS的实际URL。你可以使用工具如`ffmpeg`来完成这个转换过程。 请注意,RTSP的转换和播放可能涉及到服务器的配置和处理。这只是一个简单的示例,你可能需要根据你的实际需求做一些调整和改进。 希望这个解决方案对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fruge365

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值