vue视频录制 限制大小,限制时长

<template><div style="height: 100vh;background: #000;"><span style="color: #fff;font-size: 18px;">切换数量:{{ devices.length }}</span><video ref="video" autoplay muted playsinline></video><div class="video_btn"><van-button round @click="start" type="info">{{ isRecording ? `${timernum}秒后停止录制` : '开始录制' }}</van-button><van-button round @click="switchCamera" :disabled="isRecording">切换摄像头</van-button></div><video v-if="recordedVideoUrl" :src="recordedVideoUrl" controls></video></div>
</template><script>
export default {data() {return {mediaStream: null, // 摄像头视频流mediaRecorder: null, // 媒体录制器recordedChunks: [], // 录制的数据块recordedVideoUrl: null, // 录制后的视频 URLisRecording: false, // 是否正在录制currentDeviceId: null, // 当前摄像头设备 IDcurrentText: true, // true前 false后devices: [], // 设备列表timer: null, // 计时器,用于限制录制时间timernum: 30, // 计时器,用于限制录制时间maxFileSize: 100 * 1024 * 1024, // 100MB}},mounted() {this.startCamera()},methods: {async startCamera() {try {// 获取设备列表const devices = await navigator.mediaDevices.enumerateDevices()this.devices = devices.filter(device => device.kind === "videoinput")if (this.devices.length === 0) {throw new Error("没有找到摄像头设备")}// 默认选择第一个设备 首次前置this.currentDeviceId = this.devices[0].deviceId// 获取视频流并绑定this.mediaStream = await navigator.mediaDevices.getUserMedia({video: { deviceId: this.currentDeviceId }})const videoElement = this.$refs.videovideoElement.srcObject = this.mediaStream} catch (error) {console.error("无法访问摄像头:", error)}},// 开始录制或停止录制start() {if (this.isRecording) {this.stopRecording()} else {this.startRecording()}},startRecording() {if (this.mediaStream) {this.mediaRecorder = new MediaRecorder(this.mediaStream)this.recordedChunks = []this.mediaRecorder.ondataavailable = (event) => {if (event.data.size > 0) {this.recordedChunks.push(event.data)// 检查文件大小是否超过 95MBconst totalSize = this.recordedChunks.reduce((acc, chunk) => acc + chunk.size, 0)if (totalSize > this.maxFileSize) {this.stopRecording()}}}this.mediaRecorder.onstop = () => {const blob = new Blob(this.recordedChunks, { type: "video/webm" })this.recordedVideoUrl = URL.createObjectURL(blob)}this.timer = setInterval(() => {this.settime()}, 1000) // 60秒后停止录制this.mediaRecorder.start()this.isRecording = true}},settime() {if (this.timernum < 1) {this.stopRecording()clearInterval(this.timer)return} else {this.timernum--}},stopRecording() {if (this.mediaRecorder) {this.mediaRecorder.stop()clearInterval(this.timer) // 停止定时器this.isRecording = false}this.timernum = 30},async switchCamera() {// if (this.currentText) {//   this.$toast('数值:' + this.currentText)//   this.currentText = false// } else {//   this.$toast('数值:' + this.currentText)//   this.currentText = true// }// returntry {// 停止当前的媒体流this.stopStream()// 切换到下一个摄像头设备(循环切换)const devices = await navigator.mediaDevices.enumerateDevices()this.devices = devices.filter(device => device.kind === "videoinput")let currentIndex = 0if (this.devices.length == 2) {currentIndex = this.devices.findIndex(device => device.deviceId === this.currentDeviceId)const nextIndex = (currentIndex + 1) % this.devices.lengththis.currentDeviceId = this.devices[nextIndex].deviceId} else if (this.devices.length > 2) {if (this.currentText) {this.currentDeviceId = this.devices[1].deviceIdthis.currentText = false} else {this.currentDeviceId = this.devices[0].deviceIdthis.currentText = true}}// 获取新的摄像头流this.mediaStream = await navigator.mediaDevices.getUserMedia({video: { deviceId: this.currentDeviceId }})const videoElement = this.$refs.videovideoElement.srcObject = this.mediaStream} catch (error) {this.$toast('无法切换摄像头' + error)}},stopStream() {if (this.mediaStream) {const tracks = this.mediaStream.getTracks()tracks.forEach(track => track.stop())}}}
}
</script><style>
.video_btn {position: fixed;bottom: 30px;z-index: 99;display: flex;justify-content: space-around;align-items: center;width: 100%;max-width: 640px;margin: 0 auto;
}video {width: 100%;height: 80vh;max-width: 640px;margin: 0 auto;
}
</style>

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

若依框架之简历pdf文档预览功能

一、前端 &#xff08;1&#xff09;安装插件vue-pdf&#xff1a;npm install vue-pdf &#xff08;2&#xff09;引入方式&#xff1a;import pdf from "vue-pdf"; &#xff08;3&#xff09;components注入方式&#xff1a;components:{pdf} &#xff08;4&…

永磁同步电机负载估计算法--自适应龙伯格观测器

一、原理介绍 龙贝格扰动观测器的参数可以通过带宽配置法进行整定&#xff0c;将观测器带宽设为L&#xff0c;选取大的L可以加快观测器的收敛速度&#xff0c;但是L过大会导致系统阶跃响应出现超调、稳态性能差等问题。因此&#xff0c;在龙贝格观测器中引入表征系统状态变量x…

Python机器学习笔记(十七、分箱、离散化、线性模型与树)

数据表示的最佳方法&#xff1a;取决于数据的语义&#xff0c;所使用的模型种类。 线性模型与基于树的模型&#xff08;决策树、梯度提升树和随机森林&#xff09;是两种成员很多同时又非常常用的模 型&#xff0c;它们在处理不同的特征表示时就具有非常不同的性质。我们使用w…

Spring Boot介绍、入门案例、环境准备、POM文件解读

文章目录 1.Spring Boot(脚手架)2.微服务3.环境准备3.1创建SpringBoot项目3.2导入SpringBoot相关依赖3.3编写一个主程序&#xff1b;启动Spring Boot应用3.4编写相关的Controller、Service3.5运行主程序测试3.6简化部署 4.Hello World探究4.1POM文件4.1.1父项目4.1.2父项目的父…

嵌入式入门Day35

网络编程 Day2 套接字socket基于TCP通信的流程服务器端客户端TCP通信API 基于UDP通信的流程服务器端客户端 作业 套接字socket socket套接字本质是一个特殊的文件&#xff0c;在原始的Linux中&#xff0c;它和管道&#xff0c;消息队列&#xff0c;共享内存&#xff0c;信号等…

安卓系统主板_迷你安卓主板定制开发_联发科MTK安卓主板方案

安卓主板搭载联发科MT8766处理器&#xff0c;采用了四核Cortex-A53架构&#xff0c;高效能和低功耗设计。其在4G网络待机时的电流消耗仅为10-15mA/h&#xff0c;支持高达2.0GHz的主频。主板内置IMG GE832 GPU&#xff0c;运行Android 9.0系统&#xff0c;内存配置选项丰富&…

centos,789使用mamba快速安装R及语言包devtools

如何进入R语言运行环境请参考&#xff1a;Centos7_miniconda_devtools安装_R语言入门之R包的安装_r语言devtools包怎么安装-CSDN博客 在R里面使用安装devtools经常遇到依赖问题&#xff0c;排除过程过于费时&#xff0c;使用conda安装包等待时间长等。下面演示centos,789都是一…

人工智能(AI)简史:推动新时代的科技力量

一、人工智能简介 人工智能&#xff08;AI&#xff0c;Artificial Intelligence&#xff09;是计算机科学的一个分支&#xff0c;旨在研究和开发可以模拟、扩展或增强人类智能的系统。它涉及多种技术和方法&#xff0c;包括机器学习、深度学习、自然语言处理&#xff08;NLP&a…

【笔记】在虚拟机中通过apache2给一个主机上配置多个web服务器

&#xff08;配置出来的web服务器又叫虚拟主机……&#xff09; 下载apache2 sudo apt update sudo apt install apache2 &#xff08;一&#xff09;ip相同 web端口不同的web服务器 进入 /var/www/html 创建站点一和站点二的目录文件&#xff08;目录文件名自定义哈&#x…

linux装git

前言 以 deepin 深度系统为例&#xff0c;安装命 令行版 Git 非常简单。 安装 注意&#xff1a;需要输入账号密码&#xff0c;否则无法进行。 打开终端&#xff0c;执行如下命令即可。 sudo apt-get install git成功 如下图所示&#xff0c;输入 git &#xff0c;命令识别即…

【Spark】架构与核心组件:大数据时代的必备技能(下)

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《大数据前沿&#xff1a;技术与应用并进》&#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、引言 1、什么是Apache Spark 2、Spark 的应用场景&…

NLP中的神经网络基础

一&#xff1a;多层感知器模型 1&#xff1a;感知器 解释一下&#xff0c;为什么写成 wxb>0 &#xff0c;其实原本是 wx > t ,t就是阈值&#xff0c;超过这个阈值fx就为1&#xff0c;现在把t放在左边。 在感知器里面涉及到两个问题&#xff1a; 第一个&#xff0c;特征提…

第十一章 图论

题目描述&#xff1a; 阿里这学期修了计算机组织和架构课程。他了解到指令之间可能存在依赖关系&#xff0c;比如WAR&#xff08;读后写&#xff09;、WAW、RAW。 如果两个指令之间的距离小于安全距离&#xff0c;则会导致危险&#xff0c;从而可能导致错误的结果。因此&#…

嵌入式系统 第七讲 ARM-Linux内核

• 7.1 ARM-Linux内核简介 • 内核&#xff1a;是一个操作系统的核心。是基于硬件的第一层软件扩充&#xff0c; 提供操作系统的最基本的功能&#xff0c;是操作系统工作的基础&#xff0c;它负责管理系统的进程、内存、设备驱动程序、文件和网络系统&#xff0c; 决定着系统的…

win11蓝屏死机 TPM-WMI

1. 打开win11的事件查看器&#xff0c;定位错误 最近两次都是 KB5016061&#xff1a;安全启动数据库和 DBX 变量更新事件 - Microsoft 支持 事件源 TPM-WMI 事件 ID 1796 2. 解决方案 打开注册表&#xff1a;计算机\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Contro…

Linux命令——3.网络与用户

文章目录 一、网络1.网络测试与诊断2.网络接口配置3.无线网络配置4.防火墙与网络管理6.防火墙管理1&#xff09;firewalld命令2&#xff09;iptables命令 二、用户和群组1.管理员模式2.用户账户管理1&#xff09;useradd创建2&#xff09;usermod修改3&#xff09;userdel 删除…

机器学习算法基础知识1:决策树

机器学习算法基础知识1&#xff1a;决策树 一、本文内容与前置知识点1. 本文内容2. 前置知识点 二、场景描述三、决策树的训练1. 决策树训练方式&#xff08;1&#xff09;分类原则-Gini&#xff08;2&#xff09;分类原则-entropy&#xff08;3&#xff09;加权系数-样本量&am…

_使用CLion的Vcpkg安装SDL2,添加至CMakelists时报错,编译报错

语言&#xff1a;C20 编译器&#xff1a;gcc 14.2 摘要&#xff1a;初次使用Vcpkg添加SDL2&#xff0c;出现CMakelists找不到错误、编译缺失main错误、运行失败错误。 CMakelists缺失错误&#xff1a; 使用CLion的Vcpkg安装SDL2时&#xff0c;按照指示把对应代码添加至CMakel…

Lumos学习王佩丰Excel第二十二讲:制作甘特图与动态甘特图

一、制作双向条形图 1. 分离坐标轴 2. 自定义坐标轴数字格式&#xff1a;加分号加正常数字 3. 修改图表背景 修改图片艺术效果&#xff1a;虚化图片 二、制作甘特图 1、甘特图定义 甘特图&#xff08;Gantt chart&#xff09;又称为横道图、条状图&#xff08;Bar chart&…

el-pagination 为什么只能展示 10 条数据(element-ui@2.15.13)

好的&#xff0c;我来帮你分析前端为什么只能展示 10 条数据&#xff0c;以及如何解决这个问题。 问题分析&#xff1a; pageSize 的值&#xff1a; 你的 el-pagination 组件中&#xff0c;pageSize 的值被设置为 10&#xff1a;<el-pagination:current-page"current…