gpt4 book ai didi

web-audio-api - 如何使用 WebAudio 将多个立体声信号混合为一个信号?

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

我正在编写一个网络应用程序,它需要将多个立体声组合成一个立体声输出,所以我想要一个相当于 gstreamer's audiomixer element 的应用程序,但 WebAudio 中似乎没有。 ChannelMerger 并没有做完全相同的事情 - 它将多个单声道信号组合成一个多声道信号。

AudioNode.connect 的文档说您可以将一个输出连接到其他节点的多个输入,并且尝试将同一输出多次连接到同一输入的尝试将被忽略。但它并没有说明如果您尝试将多个不同的输出连接到同一输入会发生什么。那会像我想要的那样充当简单的混音器吗?我怀疑不是,因为 WebAudio 提供的分离/合并功能(参见上面的 ChannelMerger)似乎主要是基于多个单声道信号和一个多声道信号之间的转换,以及一个声道到一个单声道信号的映射。

我可以采用任意节点(我想 GainNode 可以工作,我可以利用它的增益功能)并将其 channel 解释模式设置为“扬声器”以实际混合 channel ,但它仅适用于 1、2、 4 或 6 个输入。我不太可能需要超过 6 个,但我肯定需要能够处理 3 个,可能还有 5 个。这可以通过使用多个混音器来完成(例如,对于三个 channel ,在一个混音器中混合输入 1 和 2,然后在第二个混音器中将其输出与输入 3 混合),但我认为我必须添加更多 GainNode 才能正确平衡混音。混频器可能必须衰减每个输入以防止重合峰值超出范围,因此对于没有补偿的链式混频器,我最终会得到 1/4、1/4、1/2 而不是 1/3、1/3 ,1/3?

最佳答案

你几乎做对了。使用单个 GainNode 并将每个源连接到 GainNode 的单个输入。这将总结所有不同的连接并产生单个输出。如果您知道所有单独的来源都是立体声,则无需更改有关 channelInterpretationchannelCountModechannelCount 的任何内容即可获得你想要什么。

您可能必须调整 GainNode 的增益值以降低输出音量,这样您就不会过度驱动输出设备。

除此之外,这应该都有效。

关于web-audio-api - 如何使用 WebAudio 将多个立体声信号混合为一个信号?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53684376/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com