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

文章目录

  • 一、安装ffmpeg
  • 二、配置系统ffmpeg环境变量
  • 三、node搭建websocket服务
  • 四、vue播放视频

注意:这个方法实现了本地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也要引入

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

下班~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/594993.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

书生浦语训练营第2期-第6节作业

一、基础作业 1.1 Lagent Web Demo 使用 1.2 AgentLego 直接使用部分 二、进阶作业 2.1 AgentLego WebUI 使用 2.2 使用 Lagent 自定义工具 2.3 使用AgentLego自定义工具

Unity Navigation 入门(新版)

概述 在游戏的制作过程中&#xff0c;寻路功能一定是非常重要的部分&#xff0c;他可以为主角寻路&#xff0c;也可以运用到敌人追击等&#xff0c;相比于自己实现的难度&#xff0c;使用寻路组件就显得简单的多&#xff0c;那接下来就开始学习这部分的内容吧 1.安装AI Naviga…

【vue+echarts】绘制中国地图,3D地图,省、市、县三级下钻以及回钻,南海诸岛小窗化显示,点位飞线图,点位名称弹窗轮播展示,及一些常见问题

先看效果展示图 目录 准备工作一, 绘制3D地图1,调用官网地址接口获取2,去官网下载中国地图的json数据到本地,本地引入 二, 南海诸岛小窗化显示1, 手动过滤掉,只保留小窗化的南海诸岛2, 代码层面过滤掉,只保留小窗化的南海诸岛 三, 省、市、县三级地图下钻及回钻1, 下钻2, 回钻…

YApi的在IDEA中的使用

1 IDEA中插件下载 2 misc.xml的配置 <component name"yapi"><option name"projectToken">XXXXXXXXXX</option><option name"projectId">47</option><option name"yapiUrl">http://XXXX:3000<…

第10篇:创建Nios II工程之控制单个七段数码管

Q&#xff1a;还记得之前使用Verilog case语句来描述实现七段数码管的逻辑功能。本期我们创建Nios II工程用C语言代码实现相同的功能。 A&#xff1a;基本原理&#xff1a;一个七段数码管由7个发光二极管LED组成&#xff0c;所以控制一个数码管的显示即控制7个LED。我们在之前…

效率工具Cmder与文件拆分

Cmder安装&#xff1a; 网站下载&#xff0c;解压缩&#xff0c;使用管理员身份打开Cmder可执行程序。 Cmder鼠标右键快捷点打开设置 样式图&#xff1a; 命令&#xff1a;以管理员的身份打开Cmder.exe, 输入命令: Cmder.exe /REGISTER ALL 执行完之后回到桌面&#xff0c;…

linux查看ip和端口

1. ip addr ip addr 或者 ip addr show 输出包含了网络接口的名称、状态、MTU&#xff08;Maximum Transmission Unit&#xff09;、链路层地址&#xff08;如MAC地址&#xff09;、IPv4和IPv6地址等信息。 2. 只需要 ip地址 ipV4 ip addr | grep inet ipV6 3.查看端口 s…

国内外主流大模型都具备有哪些特点?

文章目录 ⭐ 火爆全网的大模型起点⭐ 国外主流LLM及其特点⭐ 国内主流LLM及其特点⭐ 全球大模型生态的发展 该章节呢&#xff0c;我们主要是看一下关于国内外主流的大语言模型&#xff0c;通过它们都具备哪些特点&#xff0c;来达成对多模型有一个清晰的认知。对于 “多模型” …

python从0开始学习(三)

目录 前言 1、类型转换 1.1 隐式类型转换 1.2 显式类型转换 2、eval函数 总结 前言 上篇我们讲了python中的变量与常量&#xff0c;以及变量类型。本篇文章将接着往下讲。 1、类型转换 python中的数据类型转换包括两种&#xff1a;隐式类型转换和显式类型转换。 1.1 隐式…

数据库开发关键之与DQL查询语句有关的两个案例

案例 案例1 条件分页查询 查看项目经理提供给我们的需求文档 模糊匹配的含义是 只要包含"张"就可以 use dduo;-- 按照需求完成员工管理的条件分页查询 根据输入条件 查询第一页的数据 每页展示10条记录 -- 输入条件&#xff1a; -- 姓名&#xff1a; 张 -- 年龄&…

JavaScript之数据类型(1)

数据类型的分类&#xff1a; 我们可以将数据类型分为简单数据类型&#xff0c;复杂数据类型。 简单数据类型&#xff1a; 简介&#xff1a; 数据类型说明默认值Number数字型&#xff0c;包含 整型值和浮点型值&#xff0c;如 21、0.210Boolean布尔值类型&#xff0c;如 true、…

防泄密,防飞单!好用的企业电脑监控软件推荐

公司辛辛苦苦维护的客户被竞争对手抢先 成本报价被窃取&#xff0c;公司失去先机…… 员工泄露公司数据和飞单问题一直是企业面临的重要挑战。这些行为不仅可能导致企业遭受重大的经济损失&#xff0c;还可能损害企业的声誉和客户关系。因此&#xff0c;企业需要采取一系列措…

19_Scala集合概述

文章目录 集合回顾javaScala集合三大类String & StringBuilderScala集合两大类 集合 回顾java scala与Java有所不同 函数式编程语言更侧重集合本身提供的哪些功能&#xff1b; Scala集合三大类 1.Seq 存储有序数据可重复 类比 List 2.Set 存储无序数据不可重复 3.Map…

ttkbootstrap界面美化系列之Menubutton(五)

一&#xff1a;Menubutton接口 print(help(help(ttk.Menubutton))) Help on class Menubutton in module tkinter.ttk:class Menubutton(Widget)| Menubutton(masterNone, **kw)|| Ttk Menubutton widget displays a textual label and/or image, and| displays a menu wh…

【MySQL】第一次作业

【MySQL】第一次作业 1、在官网下载安装包2、解压安装包&#xff0c;创建一个dev_soft文件夹&#xff0c;解压到里面。3、创建一个数据库db_classes4、创建一行表db_hero5、将四大名著中的常见人物插入这个英雄表 写一篇博客&#xff0c;在window系统安装MySQL将本机的MySQL一定…

spring源码分析之AOP开启注解

AOP开启注解 在使用注解Aspect来进行AOP操作时&#xff0c;需要在xml中进行配置 <!-- 使Aspect注解生效 --><aop:aspectj-autoproxy/> 创建BeanFactory时obtainFreshBeanFactory()在解析xml加载BeanDefinition中&#xff0c;执行parseBeanDefinitions方法进行解析发…

指挥中心操作台的选择至关重要

在指挥中心的环境中&#xff0c;操作台是核心设备&#xff0c;它承载着信息收集、处理、分发的重要任务。其选择应考虑到多方面的因素&#xff0c;包括外观、材质、稳定性、操作便利性以及技术支持等。嘉德立在这里给大家详细的总结一下选择指挥中心操作台的要点。 首先&#x…

5.Spring Security-web权限方案

设置登录的用户名和密码 1.通过配置文件设置用户名密码 spring:security:user:name: xiankejinpassword: 123456 如果没有以上配置&#xff0c;那么就会在后台生成一个随机密码&#xff0c;用户名固定位user。 2.通过配置类设置用户名密码 Configuration public class Sec…

【AIGC】深入探索AIGC技术在文本生成与音频生成领域的应用

&#x1f680;文章标题 &#x1f680;AIGC之文本生成&#x1f680;应用型文本生成&#x1f680;创作型文本生成&#x1f680;文本辅助生成&#x1f680;重点关注场景 &#x1f680;音频及文字—音频生成&#x1f680;TTS(Text-to-speech)场景&#x1f680;乐曲/歌曲生成&#x…

给股东送酱的公司值得关注吗?仲景食品-300908 年报分析(20240505)

仲景食品-300908 基本情况 公司名称&#xff1a;仲景食品股份有限公司 A股简称&#xff1a;仲景食品 成立日期&#xff1a;2002-09-29 上市日期&#xff1a;2020-11-23 所属行业&#xff1a;食品制造业 周期性&#xff1a;0 主营业务&#xff1a;调味配料和调味食品的研发、生产…
最新文章