pcm 修改采样率

博客涉及前端领域,运用JavaScript处理PCM相关内容,虽未给出具体内容,但可知围绕前端技术展开,利用JavaScript对PCM进行操作或应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

let outputArray = this.base64ToArrayBuffer(voice);//base64转ArrayBuffer
//AllData.push(outputArray);
let arr16 = new Int16Array(outputArray.buffer);//转换init16Array
let voice_data = this.dealVoice([arr16], 8000, 16000);//升采样率
let Base64_test = this.arrayBufferToBase64(voice_data.data);//

arrayBufferToBase64: function (buffer) {
      var binary = "";
      var bytes = new Uint8Array(buffer.buffer);
      var len = bytes.byteLength;
      for (var i = 0; i < len; i++) {
        binary += String.fromCharCode(bytes[i]);
      }
      return window.btoa(binary);
}
base64ToArrayBuffer(base64String) {
      const padding = "=".repeat((4 - (base64String.length % 4)) % 4);
      const base64 = (base64String + padding)
        .replace(/\-/g, "+")
        .replace(/_/g, "/");

      const rawData = window.atob(base64);
      const outputArray = new Uint8Array(rawData.length);

      for (let i = 0; i < rawData.length; ++i) {
        outputArray[i] = rawData.charCodeAt(i);
      }
      return outputArray;
    },

dealVoice(pcmDatas, pcmSampleRate, newSampleRate) {
      var size = 0;
      for (var i = 0; i < pcmDatas.length; i++) {
        size += pcmDatas[i].length;
      }

      var step = newSampleRate / pcmSampleRate;
      if (step <= 1) {
        //新采样不高于pcm采样率不处理
        step = 1;
        newSampleRate = pcmSampleRate;
      } else {
        size = Math.floor(size * step);
      }

      var res = new Int16Array(size);

      //处理数据
      var posFloat = 0,
        prev = 0;
      for (var index = 0, nl = pcmDatas.length; index < nl; index++) {
        var arr = pcmDatas[index];
        for (var i = 0; i < arr.length; i++) {
          var cur = arr[i];

          var pos = Math.floor(posFloat);
          posFloat += step;
          var end = Math.floor(posFloat);

          //简单的从prev平滑填充到cur,有效减少转换引入的杂音
          var n = (cur - prev) / (end - pos);
          for (var j = 1; pos < end; pos++, j++) {
            //res[pos]=cur;
            res[pos] = Math.floor(prev + j * n);
          }

          prev = cur;
        }
      }

      return {
        sampleRate: newSampleRate,
        data: res,
      };
    },

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值