gpt4 book ai didi

javascript - 将audioContext转换回缓冲区

转载 作者:行者123 更新时间:2023-12-02 23:27:05 25 4
gpt4 key购买 nike

我有一个audioContext从createMediaElementSource获取其媒体。我想将音频解析为AudioBuffers或类似的东西,我可以通过websocket发送给另一个客户端。

let audioElement = document.querySelector('video')
let audioContext = new window.AudioContext()
let source = audioContext.createMediaElementSource(audioElement)
source.connect(deliverToOtherClientOrSomething)

我尝试制作 AudioWorkletNode,但是这种方法的问题是它不允许我在此处结束链,而是迫使我将音频转发到其他AudioContext元素,这是不必要的。

最佳答案

因此,最后通过使用音频工作集节点解决了该问题。创建AudioWorkletNode时,可以将选项传递给它。选项之一是numberOfOutputs。通过这样做,我的问题得到了完全回答。

主文件

const sendProcessor = new AudioWorkletNode(audioContext, 'send-processor', {numberOfOutputs:0})
sendProcessor.port.onmessage = (event) => {
callback(event.data);
}

处理器文件
process(inputs, outputs) {
this.port.postMessage(inputs[0][0]);
return true;
}

关于javascript - 将audioContext转换回缓冲区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61217807/

25 4 0