Vue中使用js-audio-recorder实现录音

Vue中使用js-audio-recorder实现录音

使用步骤:

  1. 安装
npm i js-audio-recorder
  1. vue文件中引入
import Recorder from 'js-audio-recorder'
  1. 使用
 - mounted 中创建recorder 
 mounted() {
    this.recorder = new Recorder({
      sampleBits: 16, // 采样位数,支持 8 或 16,默认是16
      sampleRate: 16000, // 采样率,支持 11025、16000、22050、24000、44100、48000,根据浏览器默认值,我的chrome是48000
      numChannels: 1, // 声道,支持 1 或 2, 默认是1
    });
  },
  
 - methods中使用Recorder中相关方法
 methods: {
    mousedown() {
      // Recorder.getPermission用于获取网页麦克风权限
      Recorder.getPermission().then(
        () => {
          this.recorder.start(); // 开始录音
        },
        (error) => {
          this.$message({
            message:
              "请先允许该网页使用麦克风",
            type: "info",
          });
        }
      );
    },
    mouseup() {
      let that = this;
      this.recorder.stop(); // 停止录音
      if (this.recorder == null || this.recorder.duration === 0) {
        this.$message({
          message: "请先录音",
          type: "error",
        });
        return false;
      }
      const formData = new FormData();
      const blob = this.recorder.getWAVBlob(); // 获取wav格式音频数据
      // 此处获取到blob对象后需要设置fileName满足当前项目上传需求,其它项目可直接传把blob作为file塞入formData
      const newbolb = new Blob([blob], { type: "audio/wav" });
      const fileOfBlob = new File([newbolb], new Date().getTime() + ".wav");
      formData.append("file", fileOfBlob);
      // const url = window.URL.createObjectURL(fileOfBlob);
      // this.src = url;

      // this.recorder.downloadWAV(); // 下载语音文件

      // audioToText上传音频文件接口
      that.$api.audioToText(formData).then((res) => {
        if (res.code == 200) {
          if (res.data.status == 20000000) {
            // 接口返回音频转换的文字
            this.keyWord = res.data.result;
            // 路由跳转并将文字带过去
            that.$router.push({
              path: "/resourceStatistics",
              query: {
                keyWord: that.keyWord,
              },
            });
          } else {
            this.$message({
              message: "系统异常,请稍后再试!",
              type: "error",
            });
          }
        }
      });
    },
  },

备注

  • 采样率一定要和后端保持一致,否则语音转文字不准确(后端使用阿里云语音)
  • 本地localhost可以使用语音,http协议(不论本地或线上)均无法使用语音,这是因为网页认为http协议是不安全的,因此http请求的 chrome,edge, fireFox 等主流浏览器由于安全限制将不会暴露getUserMedia 方法,所以就不能够访问用户的媒体设备。

http协议无法使用麦克风权限的解决方案:

  • chrome浏览器访问如下地址:
    chrome://flags/#unsafely-treat-insecure-origin-as-secure

  • chrome浏览器配置
    在这里插入图片描述

  • edge浏览器配置
    edge://flags/#unsafely-treat-insecure-origin-as-secure

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js是一款流行的JavaScript框架,可用于构建Web应用程序。要在Vue.js应用程序实现录音功能,您可以使用第三方JavaScriptJS Audio Recorder。该库提供了一个简单易用的API,可用于录制音频,并生成波形图。 要生成波形图,您可以使用WaveSurfer.js库。它是一个用于Web音频可视化的JavaScript库,可用于显示音频波形图。 以下是一些步骤来使用JS Audio Recorder和WaveSurfer.js实现Vue.js录音功能并生成波形图: 1.安装JS Audio Recorder和WaveSurfer.js 您可以使用npm安装这些库: ``` npm install jrecorder wavesurfer.js ``` 2.在Vue.js应用程序引入库 您需要在Vue.js组件引入这些库: ```javascript import JRecorder from 'jrecorder'; import WaveSurfer from 'wavesurfer.js'; ``` 3.创建录音器对象 您可以创建一个JS Audio Recorder对象来处理录音。您需要指定配置选项,如音频格式、采样率和位深度等。例如: ```javascript const recorder = new JRecorder({ workerPath: '/path/to/recorderWorker.js', encoding: 'mp3', numChannels: 2, sampleRate: 44100, bitRate: 192000, bufferSize: 16384, onAnalysed: function(data) { // 处理波形数据 } }); ``` 4.创建波形图对象 您可以使用WaveSurfer.js创建波形图对象。您需要指定DOM元素和配置选项。例如: ```javascript const waveform = WaveSurfer.create({ container: '#waveform', waveColor: '#888', progressColor: '#333' }); ``` 5.开始录音 当用户点击“录音”按钮时,您可以调用recorder.startRecording()来开始录音。同时,您可以调用waveform.recordStart()来开始绘制波形图。 ```javascript recorder.startRecording(); waveform.recordStart(); ``` 6.停止录音 当用户点击“停止”按钮时,您可以调用recorder.stopRecording()来停止录音。同时,您可以调用waveform.recordStop()来停止绘制波形图。最后,您可以调用waveform.loadBlob(blob)来加载录制的音频数据并绘制完整的波形图。 ```javascript recorder.stopRecording(function(blob) { waveform.recordStop(); waveform.loadBlob(blob); }); ``` 以上是实现Vue.js录音功能并生成波形图的基本步骤。如果您需要更多详细信息,请参考JS Audio Recorder和WaveSurfer.js的官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值