我有一系列具有开始时间偏移的 mp3 文件。
我正在尝试将它们与 adelay 和 amix 合并在一起。
以下代码运行并创建组合的 MP3,但是当我收听最终的输出文件时,发现有些地方人们在互相交谈,这并不是说他们很粗鲁,而是音频不同步。
以下是包含开始和停止时间偏移的文件:
d4a19a58-790a-45c1-b96e-819bc98cd408.webm | 1720 | 3762173
ab794f92-bdfb-4bb0-821d-ba80c8a9228a.webm | 48920 | 3328385
a7df9a51-0671-4930-a14b-e7d85a562577.webm | 76220 | 3763361
5d312878-d25d-40d7-9418-bed85e22efc6.webm | 3109640 | 3267473
1cf6127d-250a-4601-a219-b1b6bbd725f8.webm | 3360980 | 3636927
c3ddd462-e05a-425f-af58-f288f930f2cb.webm | 3689600 | 3760423
下面是我用来将 webm 文件转换为 MP3 的命令,为了便于阅读,将其分成几行:
ffmpeg
-acodec libopus
-i d4a19a58-790a-45c1-b96e-819bc98cd408.webm
-b:a 320K
-vn
-y d4a19a58-790a-45c1-b96e-819bc98cd408.mp3
为了便于阅读,以下命令将所有 mp3 合并为行:
ffmpeg
-i d4a19a58-790a-45c1-b96e-819bc98cd408.mp3
-i ab794f92-bdfb-4bb0-821d-ba80c8a9228a.mp3
-i a7df9a51-0671-4930-a14b-e7d85a562577.mp3
-i 1cf6127d-250a-4601-a219-b1b6bbd725f8.mp3
-i c3ddd462-e05a-425f-af58-f288f930f2cb.mp3
-filter_complex "
[0]adelay=1720|1720[a0];
[1]adelay=48920|48920[a1];
[2]adelay=76220|76220[a2];
[3]adelay=3360980|3360980[a3];
[4]adelay=3689600|3689600[a4];
[a0][a1][a2][a3][a4]amix=inputs=5
"
out.mp3 -y
对于我做错什么有什么想法吗?
答案1
您需要使用相同的值延迟所有音频通道adelay=毫秒:全部=true并使用-异步 1在命令的末尾,ffmpeg 只会纠正音频流的开始,而不是拉伸/挤压。
所以就你的情况而言:
ffmpeg
-i input1.webm
-i input2.webm
-i input3.webm
-i input4.webm
-i input5.webm
-filter_complex "
[0]adelay=1720:all=true[a0];
[1]adelay=48920:all=true[a1];
[2]adelay=76220:all=true[a2];
[3]adelay=3360980:all=true[a3];
[4]adelay=3689600:all=true[a4];
[a0][a1][a2][a3][a4]amix=inputs=5 [out]
"
-map "[out]"
out.webm -async 1 -y
正如文件所述:
-异步每秒样本数
音频同步方法。“拉伸/压缩”音频流以匹配时间戳,参数是音频每秒改变的最大样本数。-async 1 是一种特殊情况,其中仅纠正音频流的开始,而不进行任何后续纠正。