利用recordRTC实现录音

工作中实际运用到录音效果,且将录音相关功能已封装到一个js 文件中,调用方便,在此存档。
参考文档:recordRTC
将一些方法进行封装,页面按钮录音,暂停,播放等进行直接调用即可;

/* eslint-disable no-buffer-constructor,radix */
import fs from 'fs';
import RecordRTC from 'recordrtc';
import {
   
   p_fs} from './mkdirp'; // 内部疯转的异步写文件事件

let recorder;
let recorderState = '';

export default class RecAudio {
   
   
  // 检查MIC
  static captureMicrophone(callback, errcb) {
   
   
    navigator.getUserMedia = navigator.mediaDevices.getUserMedia || navigator.getUserMedia || navigator.mozGetUserMedia || navigator.webkitGetUserMedia;
    navigator.getUserMedia({
   
    audio: true}, callback, () => {
   
   
      if (errcb) {
   
    errcb(); }
    });
  }

  // 通过audio控件播放录好的声音缓存
  static playBlob(audio) {
   
   
    // recorder.reset();
    if (recorder) {
   
   
      // eslint-disable-next-line no-param-reassign
      audio.src = URL.createObjectURL(recorder.getBlob());
      audio.play();
    } // else console.log('recorder not found');
  }

  // 通过audio控件播放录好的文件
  static playFile(file, audio) {
   
   
    fs.readFile(file, (err, d
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值