![如何使用 ffmpeg 在軌道之間添加特定長度的靜音?](https://rvso.com/image/1595528/%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8%20ffmpeg%20%E5%9C%A8%E8%BB%8C%E9%81%93%E4%B9%8B%E9%96%93%E6%B7%BB%E5%8A%A0%E7%89%B9%E5%AE%9A%E9%95%B7%E5%BA%A6%E7%9A%84%E9%9D%9C%E9%9F%B3%EF%BC%9F.png)
我想將多個音訊檔案與背景圖像組合起來創建視訊。我知道我可以添加帶有地圖的音訊文件
-i audio1.mp3 -i audio2.mp3 -map 0 -map 1 -map 2
但是如何在以單一影像作為背景的情況下在音訊軌道之間添加特定長度的靜音?
答案1
如果我正確理解你的問題,你可以提供多個輸入並將它們連接起來:
ffmpeg \
-loop 1 -i image.jpg
-i audio1.wav \
-f lavfi -t 5 -i anullsrc \
-i audio2.wav \
-filter_complex "[1:a][2:a][3:a]concat=n=3:v=0:a=1[outa]" \
-map 0:v -c:v copy \
-map "[outa]" -c:a aac -b:a 192k \
-shortest \
out.mkv
這是做什麼的:
這使用單一影像作為輸入#0(但您可以
-f lavfi -i testsrc
與實際視訊檔案交換)。輸入 #1 和 #3 是您要使用的兩個音訊檔案。輸入 #2 是一個過濾器,可產生五秒的靜音。
然後,您可以使用濾鏡連接所有音訊串流
concat
。例如,要新增第三個音訊文件,您需要指定兩個附加音訊輸入(靜音和實際軌道),新增
concat
篩選器的輸入標籤(即[4:a][5:a]
),然後n=3
增加到n=5
。輸出檔案原樣使用輸入視訊 (
-c:v copy
),並使用 AAC 以 192 kbit/s 重新編碼音訊。由於您正在套用過濾器,因此需要重新編碼音訊串流。此
-shortest
選項確保編碼在最短(視訊或音訊)串流結束時結束。