我目前正在使用 Web Audio API 一点点。我设法“读取”了一个麦克风并将它播放到我的扬声器上,这非常无缝。
使用 Web Audio API,我现在想将传入的音频流(又名麦克风)从 44.1kHz 重新采样到 16kHz。16kHz,因为我正在使用一些需要 16kHz 的工具。由于 44.1kHz 除以 16kHz 不是整数,我相信我不能简单地使用低通滤波器和“跳过样本”,对吧?
我还看到有人建议使用.createScriptProcessor()
,但由于它已被弃用,我觉得使用它有点不好,所以我现在正在寻找一种不同的方法。另外,我不一定需要audioContext.Destination
听到它!如果我得到重采样输出的“原始”数据,仍然可以。
到目前为止我的方法
- 创建
AudioContext({sampleRate: 16000})
--> 会引发错误:“当前不支持从具有不同采样率的 AudioContexts 连接 AudioNodes。” - 使用
OfflineAudioContext
--> 但它似乎没有流的选项(仅适用于缓冲区) - 使用
AudioWorkletProcessor
重新采样。在这种情况下,我认为我可以使用处理器对输入进行实际重新采样并输出“重新采样”的源。但我真的不知道如何重新采样它。
main.js
...
microphoneGranted: async function(stream){
audioContext = new AudioContext();
var microphone = audioContext.createMediaStreamSource(stream);
await audioContext.audioWorklet.addModule('resample_proc.js');
const resampleNode = new AudioWorkletNode(audioContext, 'resample_proc');
microphone.connect(resampleNode).connect(audioContext.destination);
}
...
resample_proc.js(假设只有一个输入和输出通道)
class ResampleProcesscor extends AudioWorkletProcessor {
...
process(inputs, outputs, parameters) {
const input = inputs[0];
const output = outputs[0];
if(input.length > 0){
const inputChannel0 = input[0];
const outputChannel0 = output[0];
for (let i = 0; i < inputChannel0.length; ++i) {
//do something with resample here?
}
return true;
}
}
}
registerProcessor('resample_proc', ResampleProcesscor);
谢谢!