(前端)录音功能实现 js-audio-recorder
1. 创建import Recorder from 'js-audio-recorder'const parameter = {sampleBits: 16, // 采样位数,支持 8 或 16,默认是16sampleRate: 8000, // 采样率,支持 11025、16000、22050、24000、44100、48000,根据浏览器默认值,我的chrome是48000numChannel
·
1. 创建
import Recorder from 'js-audio-recorder'
const parameter = {
sampleBits: 16, // 采样位数,支持 8 或 16,默认是16
sampleRate: 8000, // 采样率,支持 11025、16000、22050、24000、44100、48000,根据浏览器默认值,我的chrome是48000
numChannels: 1 // 声道,支持 1 或 2, 默认是1
}
const recorderEx = new Recorder(parameter)
2. 调取电脑录音权限并开始录音
浏览器不支持http开头的路径,认为这个路径不安全,只支持file:,https:,http://localhost,解决办法:
chrome地址栏输入:chrome://flags/#unsafely-treat-insecure-origin-as-secure
Recorder.getPermission().then(() => {
recorderEx.start() // 开始录音
}, (error: any) => {
message.error('操作失败,请检查设备是否具备录音功能!');
})
3. 结束并获取录音结果
audio/wav类型
// 暂停录音
recorderEx.stop()
// 获取录音结果
const wavBlob = recorderEx.getWAVBlob() // blob格式
const file = new window.File([wavBlob], 'name.wav', {type: 'wav'}) // 转成file类型
// 关闭并销毁录音实例
recorderEx.destroy().then(() => {
recorderEx = null
})
更多推荐
已为社区贡献1条内容
所有评论(0)