Project Icon

extendable-media-recorder

用于自定义音频编码的可扩展MediaRecorder替代方案

extendable-media-recorder是MediaRecorder的可扩展替代方案,符合MediaStream Recording规范。该项目支持原生实现和自定义音频编码器,允许输出浏览器尚未支持的文件格式。通过内部技术实现跨浏览器兼容,并支持采样率设置。这为开发者提供了灵活的音频录制选项,适用于需要特定格式输出的应用场景。

extendable-media-recorder

一个可扩展的原生 MediaRecorder 替代品。

版本

这个包提供了MediaStream Recording规范中定义的(部分) MediaRecorder API。如果可能,它将使用原生实现。

此外,这个包还允许定义自定义编码器。这些编码器可用于渲染目前任何浏览器都不支持的文件。目前这仅适用于音频编码器。

使用方法

extendable-media-recorder 可在 npm 上获取,可以按常规方式安装。

npm install extendable-media-recorder

它导出 MediaRecorder 构造函数。可以像原生实现一样使用。以下示例将使用浏览器定义的默认编码器。

import { MediaRecorder } from 'extendable-media-recorder';

const stream = await navigator.mediaDevices.getUserMedia({ audio: true });
const mediaRecorder = new MediaRecorder(stream);

使用自定义编码器

extendable-media-recorder 还导出了一个 register() 函数,可用于定义自定义编码器。一个预定义的编码器可作为 extendable-media-recorder-wav-encoder使用。可以如下所示使用。

import { MediaRecorder, register } from 'extendable-media-recorder';
import { connect } from 'extendable-media-recorder-wav-encoder';

await register(await connect());

const stream = await navigator.mediaDevices.getUserMedia({ audio: true });
const mediaRecorder = new MediaRecorder(stream, { mimeType: 'audio/wav' });

设置采样率

MediaRecoder 无法直接修改采样率。它使用给定 MediaStreamsampleRate。您可以像这样读取正在使用的值:

const { sampleRate } = stream.getAudioTracks()[0].getSettings();

要修改录音的采样率,您需要更改 MediaStreamsampleRate。但这也是不可能的。因此,最可靠的方法是使用所需 sampleRateAudioContext 来进行重采样。

const audioContext = new AudioContext({ sampleRate: 16000 });
const mediaStreamAudioSourceNode = new MediaStreamAudioSourceNode(audioContext, { mediaStream: stream });
const mediaStreamAudioDestinationNode = new MediaStreamAudioDestinationNode(audioContext);

mediaStreamAudioSourceNode.connect(mediaStreamAudioDestinationNode);

const mediaRecorder = new MediaRecorder(mediaStreamAudioDestinationNode.stream);

内部工作原理

在内部使用两种不同的技术来启用自定义编码器。在 Chrome 中,使用原生 MediaRecorder 将流编码为带有 pcm 编码音频的 webm 文件。然后使用 ts-ebml 的最小版本来解析该 pcm 数据并将其传递给编码器。在其他浏览器中,使用 Web Audio API 获取录制音频的 pcm 数据。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号