js audio recorder plugin.
- 支持录音,暂停,恢复,和录音播放。
- 支持录音时长显示。
- 支持导出录音文件,格式为pcm或wav。
- 支持录音波形显示,可自己定制。
npm ci 或 npm i
npm run dev
npm run build
- script标签方式
<script type="text/javascript" src="./dist/recorder.js"></script>
let recorder = new Recorder();
- npm方式:
安装:
npm i js-audio-recorder
调用:
import Recorder from 'js-audio-recorder';
let recorder = new Recorder();
// 开始录音
recorder.start();
// 暂停录音
recorder.pause();
// 继续录音
recorder.resume()
// 结束录音
recorder.stop();
// 录音播放
recorder.play();
// 销毁录音实例,释放资源,fn为回调函数,
recorder.destroy(fn);
recorder = null;
// 下载pcm文件
recorder.downloadPCM();
// 下载wav文件
recorder.downloadWAV();
// 重命名pcm文件,wav也支持
recorder.downloadPCM('重命名');
// 回调持续输出时长
recorder.onprocess = function(duration) {
console.log(duration);
}
// 手动获取录音时长
console.log(recorder.duration);
recorder.getRecordAnalyseData();
返回的是一个1024长的,0-255大小的Uint8Array类型。用户可以根据这些数据自定义录音波形。
Recorder.playAudio(/* 放入blob数据 */);
支持的音乐格式由浏览器的audio支持的类型决定。
sampleBits,采样位数,默认是16
sampleRate,采样频率,浏览器默认的,我的chrome是48000
numChannels,声道数,默认是1
new Recorder时支持传入参数,
{
sampleBits: 16, // 采样位数,范围8或16
sampleRate: 16000, // 采样率,范围11025、16000、22050、24000、44100、48000
numChannels: 1, // 声道,范围1或2
}
- 拆分recorder到各个功能模块。
- 增加test代码。
- 功能完善。
- 使用127.0.0.1或localhost尝试,因为getUserMedia在高版本的chrome下需要使用https。
主要是以下几个方面:
- Web Audio Api
https://caniuse.com/#search=webaudio
- getUserMedia
https://caniuse.com/#search=getusermedia
- Typed Arrays