Javascript 将音频上下文转换回缓冲区

Javascript 将音频上下文转换回缓冲区,javascript,audio,websocket,audiocontext,Javascript,Audio,Websocket,Audiocontext,我有一个audioContext,它从createMediaElementSource获取媒体。我想把这个音频解析成音频缓冲区或者类似的东西,我可以通过WebSocket发送给另一个客户端 let audioElement = document.querySelector('video') let audioContext = new window.AudioContext() let source = audioContext.createMediaElementSource(audioEle

我有一个audioContext,它从createMediaElementSource获取媒体。我想把这个音频解析成音频缓冲区或者类似的东西,我可以通过WebSocket发送给另一个客户端

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

我尝试制作一个音频链接,但这种方法的问题是,它不允许我在那里结束链接,而是迫使我将音频转发到其他不需要的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;
}

因此,最终通过使用音频工作集节点解决了这个问题。创建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;
}