FFmpeg进行笔记本摄像头+麦克风实现流媒体直播服务,展示在浏览器上。

news2025/1/12 6:04:09

0、本文中所用软件下载包

1、前置工作

        1.1 下载 ffmpeg,Download FFmpeg,

                1.1.1配置ffmpeg如下图

                1.1.2测试ffmpeg 安装成功:ffmpeg -version

        1.1.3 使用FFmpeg获取本地摄像头设备

ffmpeg -list_devices true -f dshow -i dummy

                     video和audio地址在1.1.4会用到

        1.1.4使用FFmpeg推送RTSP视频流

ffmpeg -f dshow -i video="Integrated Webcam":audio="麦克风 (Realtek(R) Audio)" -vcodec libx264 -preset:v ultrafast -tune:v zerolatency -rtsp_transport tcp -f rtsp rtsp://127.0.0.1/test

        1.2下载easydarwin:Releases · EasyDarwin/EasyDarwin,运行EasyDarwin.exe,

 下载解压到本地后运行 EasyDarwin.exe 程序,点击运行后会弹出一个 cmd 命令,注:不要关闭弹出的命令框;在浏览器中输入 http://127.0.0.1:10008 查看是否有显示有个 web 页面,如果显示则证明打开成功。

2、node服务搭建

package.json  依赖项

{
  "name": "ssss",
  "version": "1.0.0",
  "description": "",
  "type": "module",
  "main": "index.js",
  "scripts": {
    "start": "nodemon --exec babel-node index.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@babel/cli": "^7.20.7",
    "@babel/core": "^7.20.12",
    "@babel/node": "^7.20.7",
    "@babel/preset-env": "^7.20.2",
    "@ffmpeg-installer/ffmpeg": "^1.1.0",
    "fluent-ffmpeg": "^2.1.2",
    "nodemon": "^2.0.20",
    "websocket-stream": "^5.5.2",
    "ws": "^8.12.0"
  }
}

index.js  websocket服务器+ffmpeg转码

import { WebSocketServer } from 'ws'
import webSocketStream from 'websocket-stream/stream.js'
import ffmpeg from 'fluent-ffmpeg'
import ffmpegInstaller from '@ffmpeg-installer/ffmpeg'
// 建立WebSocket服务
const wss = new WebSocketServer({ port: 8888, perMessageDeflate: false })
ffmpeg.setFfmpegPath(ffmpegInstaller.path);
// 监听连接
wss.on('connection', handleConnection)

// 连接时触发事件
function handleConnection(ws, req) {
    // 获取前端请求的流地址(前端websocket连接时后面带上流地址)
    const url = req.url.slice(1)
    console.log(url)
    // 传入连接的ws客户端 实例化一个流
    const stream = webSocketStream(ws, { binary: true })
    // 通过ffmpeg命令 对实时流进行格式转换 输出flv格式
    const ffmpegCommand = ffmpeg(url)
        .addInputOption("-rtsp_transport", "tcp", "-buffer_size", "102400", '-analyzeduration', '10000', '-max_delay', '1000')
        .on('start', function () { console.log('Stream started.') })
        .on('codecData', function () { console.log('Stream codecData.') })
        .on('error', function (err) {
            console.log('An error occured: ', err.message)
            stream.end()
        })
        .on('end', function () {
            console.log('Stream end!')
            stream.end()
        })
        .outputFormat('flv').videoCodec('copy')//.noAudio()

    stream.on('close', function () {
        ffmpegCommand.kill('SIGKILL')
    })

    try {
        // 执行命令 传输到实例流中返回给客户端
        ffmpegCommand.pipe(stream)
    } catch (error) {
        console.log(error)
    }
}

3.前端vue框架,使用flv.js获取视频数据并渲染

package.json  依赖项

{
  "name": "a",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },
  "dependencies": {
    "core-js": "^3.8.3",
    "flv.js": "^1.6.2",
    "vue": "^3.2.13"
  },
  "devDependencies": {
    "@babel/core": "^7.12.16",
    "@babel/eslint-parser": "^7.12.16",
    "@vue/cli-plugin-babel": "~5.0.0",
    "@vue/cli-plugin-eslint": "~5.0.0",
    "@vue/cli-service": "~5.0.0",
    "eslint": "^7.32.0",
    "eslint-plugin-vue": "^8.0.3"
  },
  "eslintConfig": {
    "root": true,
    "env": {
      "node": true
    },
    "extends": [
      "plugin:vue/vue3-essential",
      "eslint:recommended"
    ],
    "parserOptions": {
      "parser": "@babel/eslint-parser"
    },
    "rules": {}
  },
  "browserslist": [
    "> 1%",
    "last 2 versions",
    "not dead",
    "not ie 11"
  ]
}

vue.config.js 配置端口

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  devServer: { port: 8787 }
})

 app.vue 通过flv.js将视频流展示到页面

<template>
  <div class="wrap">
    <div @click="sound">点击播放</div>
    <video class="video" volume="0.5" controls ref="player"></video>
  </div>
</template>

<script>
import flvjs from 'flv.js' // 引入flvjs
export default {
  data() {
    return {
      player: null
    }
  },
  mounted() {

  },
  beforeUnmount() {
    // 页面销毁前 关闭flvjs
    this.player.destroy()
  },
  methods: {
    sound() {
      // 如果浏览器支持flvjs,则执行相应的程序
      if (flvjs.isSupported()) {
        this.player = null;
        // 准备监控设备流地址
        const url = 'rtsp://192.168.31.160/test'
        //ffmpeg -f dshow -i video="Integrated Webcam":audio="麦克风 (Realtek(R) Audio)" -vcodec libx264 -preset:v ultrafast -tune:v zerolatency -rtsp_transport tcp -f rtsp rtsp://127.0.0.1/test
        // 创建一个flvjs实例
        // 下面的ws://localhost:8888换成你搭建的websocket服务地址,后面加上设备流地址
        this.player = flvjs.createPlayer({
          type: 'flv',
          isLive: true,
          hasVideo: true,
          url: 'ws://192.168.31.160:8888/' + url
        })
        this.player.on('error', () => {
          //报错重置player,不重置卡着不动。
          this.player.unload()
          this.player.destroy()
          this.player = null;
          this.sound()
        })
        // 将实例挂载到video元素上面
        this.player.attachMediaElement(this.$refs.player)
        try {
          // 开始运行加载 只要流地址正常 就可以在h5页面中播放出画面了
          this.player.load()
          this.player.play()
        } catch (error) {
          console.log(error)
        }
      }
    }
  }
}
</script>

<style  scoped>
.wrap .video {
  width: 300px;
  height: 300px;
}
</style>

4.页面效果,此图是摄像头拍摄的实时画面,带麦克风声音

本文章参考以下网址:

Windows笔记本本地摄像头提供Rtsp视频流服务

FFmpeg进行笔记本摄像头+麦克风实现流媒体直播服务
html5中播放rtsp流实现监控、直播等方案

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【JavaSE】Java到底是值传递还是引用传递?

【JavaSE】Java到底是值传递还是引用传递&#xff1f; 文章目录【JavaSE】Java到底是值传递还是引用传递&#xff1f;一&#xff1a;基本数据类型和引用数据类型区别二&#xff1a;案例1&#xff1a;传递基本类型2&#xff1a;传递引用类型三&#xff1a;引用传递是怎么样的&am…

【Linux】进程信号万字详解(下)

&#x1f387;Linux&#xff1a; 博客主页&#xff1a;一起去看日落吗分享博主的在Linux中学习到的知识和遇到的问题博主的能力有限&#xff0c;出现错误希望大家不吝赐教分享给大家一句我很喜欢的话&#xff1a; 看似不起波澜的日复一日&#xff0c;一定会在某一天让你看见坚持…

搞账号登录限制?我直接用Python自制软件

前言 一个账号只能登录一台设备&#xff1f;涨价就涨价&#xff0c;至少还能借借朋友的&#xff0c;谁还没几个朋友&#xff0c;搞限制登录这一出&#xff0c;瞬间不稀罕了 这个年头谁还不会点技术了&#xff0c;直接拿python自制一个可以看视频的软件… 话不多说&#xff0…

【尚硅谷】Java数据结构与算法笔记05 -递归

文章目录一、应用场景二、递归的概念三、递归能解决的问题四、递归需要遵守的重要规则五、递归-迷宫问题六、递归-八皇后问题&#xff08;回溯算法&#xff09;6.1 问题介绍6.2 思路分析5.3 Java代码实现一、应用场景 二、递归的概念 简单的说: 递归就是方法自己调用自己, 每次…

[机器视觉]目标检测评价指标及其实现

一、模型分类目标 数据的分类情况为两类正例(Postive)和负例(Negtive)&#xff0c;分别取P和N表示。 同时在预测情况下&#xff0c;分类正确表示为T(True)&#xff0c;错误表示为F(False);便有了以下四类表示&#xff1a; TP:(True Positive 正确的判断为正例 …

投入式水位计工作原理及应用介绍

1、设备介绍&#xff1a; 投入式水位计采用国外进口传感器芯体&#xff0c;将液位压力信号转换成对应的数字信号&#xff0c;再通过数字电路处理&#xff0c;输出 RS485 两线制的标准信号。一体式设计是将隔离式传感器和数字处理电路封装在探头内&#xff0c;通过特种电缆直接…

前端性能优化(八):性能优化问题指南

目录 一&#xff1a;从输入 URL 到页面加载显示完成都发生了什么 二&#xff1a;首屏加载优化 三&#xff1a;JavaScript 内存管理 一&#xff1a;从输入 URL 到页面加载显示完成都发生了什么 UI 线程会判断输入的地址地址是搜索的关键词还是访问站点的 URL 接下来 UI 线程…

[数据结构] 详解链表(超详细)

链表可是很重要的知识,是面试时常考的知识点,这次让我们系统的学习一下吧 文章目录1. 链表的定义2. 链表的创建2.1 基础创建2.2 尾插法创建头节点2.3 头插法3. 链表的基础方法3.1 获取链表长度3.2 是否包含某个节点3.3 在任意坐标处插入节点3.4 删除第一个值为key的节点3.5 删除…

【qsort函数实现】

前言&#xff1a; 首先在进行讲解之前&#xff0c;我们先进行对函数的一些相关介绍&#xff0c;方便大家更好的理解它。 目录函数介绍函数实现函数介绍 第一步&#xff1a; 我们可以先查询知道函数的使用方法&#xff1a; void qsort (void* base, size_t num, size_t size,i…

二级路由器的设置上网

设置步骤 &#xff08;简单记录一下&#xff09; 前提条件&#xff1a;一级路由器网络正常&#xff0c;这里主要是使用 lan 口&#xff0c;需要确保各个 lan 口正常&#xff0c;我家里是移动公司的路由器&#xff0c;有一个 lan 端口专门给电视用的&#xff0c;选择它来接二级…

ZigBee 3.0实战教程-Silicon Labs EFR32+EmberZnet-5-01:片上资源详解

【源码、文档、软件、硬件、技术交流、技术支持&#xff0c;入口见文末】 【所有相关IDE、SDK和例程源码均可从群文件免费获取&#xff0c;免安装&#xff0c;解压即用】 持续更新中&#xff0c;欢迎关注&#xff01; 前面《ZigBee 3.0实战教程-Silicon Labs EFR32EmberZnet-2…

一个无线鼠标的HID Report Desc

HID设备是USB规范定义的设备类型之一&#xff0c;其分类号为0x03. 关于USB设备类型定义&#xff0c;可参见本站&#xff1a;USB设备类型定义 - USB中文网 HID设备除了用于专门的输入输出设备外&#xff0c;有时也与其它的设备类型组合成一个复杂的设备。如对于UVC摄像头设备&a…

干货!数据智能作为先进生产力,如何助力销售效能提升?

存量竞争市场中&#xff0c;企业需要通过精细化运营提升客户价值与 ROI。数据智能作为先进生产力&#xff0c;在搜索、广告、推荐业务方面已经足够成熟&#xff0c;那么它是如何助力销售提升效能呢&#xff1f;本文将详细介绍。点击文末“阅读原文”即可观看完整版直播回放&…

中科大2007年复试机试题

中科大2007年复试机试题 文章目录中科大2007年复试机试题第一题问题描述解题思路及代码第二题问题描述解题思路及代码第三题问题描述解题思路及代码第四题问题描述解题思路及代码第一题 问题描述 编写程序&#xff0c;判断给定数字是否是回文数。 示例 1 输入&#xff1a;12…

博主的心肝宝贝

写的不错的文档 Sql(Structured Query Language)语句笔记_sky wide的博客-CSDN博客常用sql语句总结https://blog.csdn.net/qq_44652591/article/details/127545318Linux samba服务配置_sky wide的博客-CSDN博客_linux samba配置但是&#xff0c;注意后面公司的需求&#xff0c;…

Docker部署Jenkins

系列文章目录 Docker部署 registry Docker搭建 svn Docker部署 Harbor Docker 部署SQL Server 2017 Docker 安装 MS SqlServer Docker部署 Oracle12c Docker部署Jenkins Docker部署Jenkins系列文章目录前言一、启动docker&#xff0c;下载Jenkins镜像文件二、创建Jenkins挂载目…

fastjson 1.2.24漏洞复现

原理 fastjson由于没有对type进行安全性验证&#xff0c;使攻击者传入危险的类&#xff0c;通过rmi服务指定的攻击机上的恶意class文件&#xff0c;导致命令执行。 版本 1.2.24 环境准备 靶机&#xff1a;ubuntu&#xff0c;192.168.52.129 攻击机&#xff1a;kali&#…

数组的定义和使用

一、一维数组的定义、初始化 1. 一维数组的定义 元素类型 数组名[常量表达式]&#xff1b; &#xff08;1&#xff09;一维数组是由元素类型、数组名和长度组成的构造类型。 &#xff08;2&#xff09;数组名必须符合C标识符规则。 &#xff08;3&#xff09;常量表…

【ONE·C || 初识C语言 】

总言 C语言初步认识。 文章目录总言1、main函数的三种写法2、常见数据类型&#xff1a;内置类型、自定义类型2.1、内置类型总述2.2、内置类型大小计算(32/64)2.3、计算机基本存储单位3、常量、变量3.1、变量3.1.1、变量的分类&#xff1a;全局变量、局部变量3.1.2、变量的作用域…

XL1278-SMT无线模块介绍

XL1278-SMT无线模块简介XL1278-SMT无线模块是采用SEMTECH公司最新的LoRaTM调制技术的无线芯片&#xff0c;该模块除传统的GFSK调制技术外&#xff0c;还采用了LoRa&#xff08;远程&#xff09;扩频技术&#xff0c;具有超远距离扩频通讯&#xff0c;高抗干扰性和最大限度的减小…