我目前正在尝试通过 webrtc 获得尽可能干净的音频通道。通过 getUserMedia mediaconstraints 对象,我设置了以下选项:
constraints: {
audio: {
mandatory: {
echoCancellation: false,
googEchoCancellation: false,
googAutoGainControl: false,
googAutoGainControl2: false,
googNoiseSuppression: false,
googHighpassFilter: false,
googTypingNoiseDetection: false,
//googAudioMirroring: false // For some reason setting googAudioMirroring causes a navigator.getUserMedia error: NavigatorUserMediaError
}
},
video: false
},
这极大地提高了音频质量,但似乎仍然存在音频处理,这会导致某些测试样本以高频噪声的形式损坏音频。
有一个 Chrome 标志--use-file-for-fake-audio-capture
如所述http://peter.sh/experiments/chromium-command-line-switches/#use-file-for-fake-audio-capture http://peter.sh/experiments/chromium-command-line-switches/#use-file-for-fake-audio-capture它允许通过文件输入进行测试。正如标志的描述中提到的,必须禁用所有音频处理,否则音频将失真 - 因此似乎有用于此目的的其他选项。
我也尝试过--disable-audio-track-processing --audio-buffer-size=16 --enable-exclusive-audio
Chrome 标志,但似乎仍然有一些音频处理。
有什么方法可以禁用仍然存在的音频处理(最好通过 JS API)?