我一直试图让一段带有多个音频流的视频静音。但效果并不理想。
尝试使用 afade 选项后,视频会保持静音。测试视频只有一个音频流可供测试。
ffmpeg -i 输入.asf -c:v 复制 -af "afade=t=out:st=10,afade=t=in:st=30" 输出.asf
我是否也需要指定所有音频流?有没有更好的方法来插入具有给定时间和持续时间的静音?
FFMPEG 输出
C:\dump\videoconvert>ffmpeg -i black.asf -c:v copy -af "afade=t=out:st=10,afade=t=in:st=30" out.asf
ffmpeg version N-66438-g4f4f08e Copyright (c) 2000-2014 the FFmpeg developers
built on Sep 24 2014 22:26:49 with gcc 4.9.1 (GCC)
configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-font
config --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-
libcaca --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3la
me --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --e
nable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab
--enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libw
ebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-zlib
libavutil 54. 7.101 / 54. 7.101
libavcodec 56. 1.101 / 56. 1.101
libavformat 56. 5.100 / 56. 5.100
libavdevice 56. 1.100 / 56. 1.100
libavfilter 5. 1.102 / 5. 1.102
libswscale 3. 1.100 / 3. 1.100
libswresample 1. 1.100 / 1. 1.100
libpostproc 53. 1.100 / 53. 1.100
Guessed Channel Layout for Input Stream #0.1 : stereo
Input #0, asf, from 'black.asf':
Metadata:
encoder : Lavf56.5.100
Duration: 00:05:49.44, start: 0.000000, bitrate: 352 kb/s
Stream #0:0: Video: msmpeg4v3 (MP43 / 0x3334504D), yuv420p, 1024x768, 15 fps, 15 tbr, 1k tbn, 1k tbc
Stream #0:1: Audio: wmav2 (a[1][0][0] / 0x0161), 44100 Hz, 2 channels, fltp, 128 kb/s
File 'out.asf' already exists. Overwrite ? [y/N] y
Output #0, asf, to 'out.asf':
Metadata:
WM/EncodingSettings: Lavf56.5.100
Stream #0:0: Video: msmpeg4v3 (MP43 / 0x3334504D), yuv420p, 1024x768, q=2-31, 15 fps, 1k tbn, 1k tbc
Stream #0:1: Audio: wmav2 (a[1][0][0] / 0x0161), 44100 Hz, stereo, fltp, 128 kb/s
Metadata:
encoder : Lavc56.1.101 wmav2
Stream mapping:
Stream #0:0 -> #0:0 (copy)
Stream #0:1 -> #0:1 (wmav2 (native) -> wmav2 (native))
Press [q] to stop, [?] for help
frame= 5240 fps=1172 q=-1.0 Lsize= 15056kB time=00:05:49.36 bitrate= 353.0kbits/s
video:8911kB audio:5459kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 4.767603%
答案1
问题
您的输出是静音的,因为淡出会使淡出后的一切变得静音,因此淡入没有任何作用。然后淡入会使一切变得静音,直到淡入发生,因此“消除”了您的第一个淡入,从而产生静音输出。
解决方案
您可以使用时间线编辑在特定时间启用过滤器。
示例命令
ffmpeg -i input.asf -af "afade=enable='between(t,10,30)':t=out:st=10,afade=enable='gte(t,30)':t=in:st=30" -c:v copy output.asf
笔记
'between(t,10,30)'
将使淡出效果在 10 至 30 秒之间生效。'gte(t,30)'
将在 30 秒时启用淡入滤镜。-c:v copy
将要流复制(重新混合)视频,因为您可能不需要对其进行过滤和重新编码。
具有多个音频流的输入
ffmpeg
您的输入可能包含多个音频流。在下面的示例控制台输出中[0:0]
,是视频,[0:1]
是第一个音频流,[0:2]
是第二个音频流:
Input #0, matroska,webm, from 'input.mkv':
Metadata:
ENCODER : Lavf56.4.101
Duration: 00:00:30.28, start: 0.068000, bitrate: 265 kb/s
Stream #0:0: Video: h264 (High 4:4:4 Predictive), yuv444p, 320x240 [SAR 1:1 DAR 4:3], 25 fps, 25 tbr, 1k tbn, 50 tbc (default)
Stream #0:1: Audio: mp3, 44100 Hz, stereo, s16p, 112 kb/s
Stream #0:2: Audio: mp3, 44100 Hz, stereo, s16p, 112 kb/s
示例命令
您必须为每个流制作淡出/淡入效果:
ffmpeg -i input.asf -filter_complex \
"[0:a:0]afade=enable='between(t,10,30)':t=out:st=10,afade=enable='gte(t,30)':t=in:st=30[a0] \
[0:a:1]afade=enable='between(t,10,30)':t=out:st=10,afade=enable='gte(t,30)':t=in:st=30[a1]" \
-map 0:v -map "[a0]" -map "[a1]" -c:v copy output.asf
笔记
使用
-filter_complex
而-af
不是复杂滤波图.复杂的过滤器图涉及一个或多个输入和一个或多个输出。[0:a:0]
指的是第一个输入的第一个音频流;或者您也可以使用[0:1]
如ffmpeg
上面的控制台输出中所示的格式,但我发现该语法不太灵活,因为对于其他输入[0:1]
可能指的是视频流。[0:a:1]
指的是第一个输入的第二个音频流;或者您也可以使用[0:2]
如ffmpeg
上面的控制台输出中所示的格式。