js的MediaRecorder录音录视频方法笔记

2024-03-15 11:04

本文主要是介绍js的MediaRecorder录音录视频方法笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   /**
   * 录音举例说明
   * https://www.cnblogs.com/zaijin-yang/p/17306578.html
   * 通过 web 录制视频(摄像头)并上传
   * https://cloud.tencent.com/developer/article/1818977?areaId=106001
   * 视频录制基础知识-MediaRecorder
   * https://www.jianshu.com/p/ad7dfd50880e
   */

import React, { useState, useEffect } from 'react'var mediaRecorder
var stream
var chunks = []
export default function App() {return (<MyRecord />);
}function MyRecord() {var [fileSize, setFileSize] = useState(0)var [url, setUrl] = useState(null)/*** 录音举例说明* https://www.cnblogs.com/zaijin-yang/p/17306578.html* 通过 web 录制视频(摄像头)并上传* https://cloud.tencent.com/developer/article/1818977?areaId=106001* 视频录制基础知识-MediaRecorder* https://www.jianshu.com/p/ad7dfd50880e*/async function initRecord() {//stream = await navigator.mediaDevices.getUserMedia({ audio: true })try {stream = await navigator.mediaDevices.getUserMedia({ video: { facingMode: 'environment' } })// const videoElement = document.querySelector('video');// videoElement.srcObject = stream;//通过调用getUserMedia方法获取摄像头的实时视频流,并将其赋值给srcObject属性,从而在网页上显示实时视频。//src适用于加载已有的静态视频文件。//srcObject适用于处理实时视频流,比如从摄像头捕获到的视频。mediaRecorder = new MediaRecorder(stream);mediaRecorder.ondataavailable = event => {if (event.data.size > 0) {console.log('======ondataavailable事件触发,chunks.length:', chunks.length);setFileSize(event.data.size)chunks.push(event.data); // 将数据块追加到 chunks 数组中  }};mediaRecorder.onstop = () => {console.log('======按下了停止录音键', mediaRecorder.mimeType);const blob = new Blob(chunks, { type: mediaRecorder.mimeType }); // 将数据块转换为 Blob  // 此时你可以使用 blob 对象,比如上传到服务器或保存到本地文件console.log('Blob created:', blob.size);const url = URL.createObjectURL(blob); //创建新的URL表示指定的blob对象const audio = document.getElementById("aaaa"); //创建标签audio.src = url;//销毁视频,释放资源URL.revokeObjectURL(url)}} catch (e) {console.log('用户禁止了摄像头权限')}}function startRecord() {chunks = []mediaRecorder.start();}function stopRecord() {/***   mediaRecorder.state返回当前状态 (闲置中,录制中或者暂停 ) (inactive, recording, or paused.)*/if (mediaRecorder.state === "recording") {mediaRecorder.stop();}}function destroyRecord() {// 终止流(这可以让浏览器上正在录音的标志消失掉)stream.getTracks().forEach(track => track.stop());stream = null;}function pauseRecord() {mediaRecorder.pause();}function resumeRecord() {mediaRecorder.resume();}var ss = { fontSize: '20px', margin: '10px' }return (<div><video id="aaaa" controls playsInline style={{ width: '300px', height: '200px' }}></video><h3>文件大小:{fileSize}</h3><button style={ss} onClick={initRecord}>初始化录音</button><button style={ss} onClick={startRecord}>开始录音</button><button style={ss} onClick={stopRecord}>停止录音</button><button style={ss} onClick={destroyRecord}>销毁录音</button><button style={ss} onClick={pauseRecord}>暂停录音</button><button style={ss} onClick={resumeRecord}>恢复录制</button></div >);
}

这篇关于js的MediaRecorder录音录视频方法笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/811752

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学