audio - 不同持续时间输入的 FFMPEG amix 滤波器音量问题

标签 audio ffmpeg

我注意到 ffmpeg amix 过滤器在特定情况下无法输出良好的结果。如果输入文件具有相同的持续时间,它就可以正常工作。在这种情况下,成交量会以恒定值下降,并且可以使用 ",volume=2" 进行修复。

就我而言,我使用不同持续时间的文件。结果体积不好。第一个混合流的音量最低,最后一个混合流的音量最高。您可以在图像上看到体积随时间线性增加。

enter image description here

我的命令:

ffmpeg -i temp_0.mp4 -i user_2123_10.mp4  -i user_2123_3.mp4  -i user_2123_4.mp4  
-i user_2123_7.mp4  -i user_2123_5.mp4  -i user_2123_1.mp4  -i user_2123_8.mp4  
-i user_2123_0.mp4  -i user_2123_6.mp4  -i user_2123_9.mp4  -i user_2123_2.mp4  
-i user_2123_11.mp4 -filter_complex "[1:a]adelay=34741.0[aud1];
[2:a]adelay=18241.0[aud2];[3:a]adelay=20602.0[aud3];
[4:a]adelay=27852.0[aud4];[5:a]adelay=22941.0[aud5];
[6:a]adelay=13142.0[aud6];[7:a]adelay=29810.0[aud7];
[8:a]adelay=12.0[aud8];[9:a]adelay=25692.0[aud9];
[10:a]adelay=32143.002[aud10];[11:a]adelay=16101.0[aud11];
[12:a]adelay=40848.0[aud12];
[0:a][aud1][aud2][aud3][aud4][aud5][aud6][aud7]
[aud8][aud9][aud10][aud11]
[aud12]amix=inputs=13:duration=first:dropout_transition=0" 
-vcodec copy -y temp_1.mp4

可以通过在每个剪辑的开头和结尾应用静音来解决这个问题,然后它们将具有相同的持续时间并且音量将处于相同的水平。

请建议我如何使用 amix 混合多个输入并确保恒定的音量水平。

最佳答案

amix1/n 缩放每个输入的音量,其中 n = no。有源输入。这是针对每个音频帧进行评估的。因此,当一个输入消失时,剩余输入的体积会按较小的量缩放,因此它们的体积会增加。

正如其他答案中所建议的,更改所有早期输入的 dropout_transition 是一种方法,但我认为这会导致粗略的音量调制。更好的方法是在混合后标准化音频。

目前,您有两个选择,loudnormdynaudnorm筛选。后者要快得多

语法是在amix之后添加它,所以

[aud11][aud12]amix=inputs=13:duration=first:dropout_transition=0,dynaudnorm"

如果您想调整参数以获得最大音量或 RMS 模式标准化等,请阅读文档

关于audio - 不同持续时间输入的 FFMPEG amix 滤波器音量问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35509147/

相关文章:

java - 单击时如何播放Listview项目的特定声音

java - Python、C/++、java...有没有用于比较音频信号的 api?

audio - FFmpeg 输出不准确

android - 检测到应用程序 native 库 libutility.so : text relocations 的问题

c# - 如何将 youtube 视频的音频 url 作为 ffmpeg 源传递

C++ 视频处理循环

c# - 访问 PC 音频输入流

javascript - 多个音频播放器的多个音量 slider

ffmpeg - 组合 2 个 FFMPEG 命令

python - pygame-混音器系统未初始化