Javascript 将音频上下文转换回缓冲区
我有一个audioContext,它从createMediaElementSource获取媒体。我想把这个音频解析成音频缓冲区或者类似的东西,我可以通过WebSocket发送给另一个客户端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
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;
}