在ffmpeg中添加静音

jon*_*jon 38 ffmpeg

我正在尝试使用ffmpeg将静音音轨添加到MOV文件中.

我创建了一个比视频更长的静音音轨,并打算在ffmpeg中使用-shortest选项.

使用SoX v14.3.1,我运行它来生成一个wav文件:

sox -n -r 44100 -b 16 -c 2 -L silence.wav trim 0.0 60.000

# -n  = Sox's null file
# -r = sample rate 
# -b = bits per sample
# -c = num of channels
# -L = little endian
# filename
# trim - is an effect, args start and length.
Run Code Online (Sandbox Code Playgroud)

我的基本ffmpeg命令如下所示:

ffmpeg -shortest \
-i silence.wav -acodec pcm_s16le \
-i vid_no_sound.mov -vcodec copy vid_with_sound.mov
Run Code Online (Sandbox Code Playgroud)

结果是:

ffmpeg version 0.11.1 Copyright (c) 2000-2012 the FFmpeg developers
  built on Aug 27 2012 13:11:25 with gcc 4.4.5
  configuration: --extra-cflags=-static --prefix=/root/ffmpeg_build/src/ffmpeg-0.11.1 --enable-bzlib --enable-gnutls --enable-libfreetype --enable-libmp3lame --enable-libdc1394 --enable-libpulse --enable-librtmp --enable-libschroedinger --enable-libtheora --enable-libvorbis --enable-libx264 --enable-libxvid --enable-openssl --enable-zlib --enable-gpl --enable-nonfree --enable-version3
  libavutil      51. 54.100 / 51. 54.100
  libavcodec     54. 23.100 / 54. 23.100
  libavformat    54.  6.100 / 54.  6.100
  libavdevice    54.  0.100 / 54.  0.100
  libavfilter     2. 77.100 /  2. 77.100
  libswscale      2.  1.100 /  2.  1.100
  libswresample   0. 15.100 /  0. 15.100
  libpostproc    52.  0.100 / 52.  0.100
[wav @ 0x29ab2e0] max_analyze_duration 5000000 reached at 5015510
Guessed Channel Layout for  Input Stream #0.0 : stereo
Input #0, wav, from 'silence.wav':
  Duration: 00:01:00.00, bitrate: 1411 kb/s
    Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 44100 Hz, stereo, s16, 1411 kb/s
Input #1, mov,mp4,m4a,3gp,3g2,mj2, from 'vid_no_sound.mov':
  Metadata:
    major_brand     : qt
    minor_version   : 537199360
    compatible_brands: qt
    creation_time   : 2012-07-25 13:41:44
  Duration: 00:00:14.50, start: 0.000000, bitrate: 27457 kb/s
    Stream #1:0(eng): Video: qtrle (rle  / 0x20656C72), rgb24, 1920x1080, 27450 kb/s, SAR 1920:1920 DAR 16:9, 24 fps, 24 tbr, 24 tbn, 24 tbc
    Metadata:
      creation_time   : 2012-07-25 13:41:44
      handler_name    : Apple Alias Data Handler
    Stream #1:1(eng): Data: none (tmcd / 0x64636D74)
    Metadata:
      creation_time   : 2012-07-25 13:42:06
      handler_name    : Apple Alias Data Handler
      timecode        : 00:00:00:00
File 'vid_with_sound.mov' already exists. Overwrite ? [y/N] y
auto-inserting filter 'auto-inserted resampler 0' between the filter 'src' and the filter 'aformat'
[aresample @ 0x2ab3b00] chl:stereo fmt:s16 r:44100Hz -> chl:stereo fmt:flt r:44100Hz
[NULL @ 0x2994320] Codec is experimental but experimental codecs are not enabled, try -strict -2
Output #0, mov, to 'vid_with_sound.mov':
    Stream #0:0(eng): Video: qtrle (rle  / 0x20656C72), rgb24, 1920x1080 [SAR 1920:1920 DAR 16:9], q=2-31, 27450 kb/s, 24 fps, 90k tbn, 24 tbc
    Metadata:
      creation_time   : 2012-07-25 13:41:44
      handler_name    : Apple Alias Data Handler
    Stream #0:1: Audio: none, 44100 Hz, stereo, flt, 128 kb/s
Stream mapping:
  Stream #1:0 -> #0:0 (copy)
  Stream #0:0 -> #0:1 (pcm_s16le -> aac)
Error while opening encoder for output stream #0:1 - maybe incorrect parameters such as bit_rate, rate, width or height
Run Code Online (Sandbox Code Playgroud)

我已经尝试添加-strict -2建议,虽然我不知道在命令行中将它放在何处.

我花了两个小时尝试不同的东西并阅读ffmpeg文档,但我仍然卡住了.

如何将静音音轨添加到mov文件?

llo*_*gan 92

anullsrc 音频过滤器

您可以使用ffmpeg创建静音音频并一步将其与视频组合.此示例将使用anullsrc音频滤波器生成采样率为44100的立体声静音音频:

ffmpeg -f lavfi -i anullsrc=channel_layout=stereo:sample_rate=44100 -i video.mov \
  -shortest -c:v copy -c:a aac output.mov
Run Code Online (Sandbox Code Playgroud)
  • channel_layout=stereo:sample_rate=44100 是默认值,但我只是作为如何使用这些选项的示例.

忽略现有音频

如果您的视频输入文件包含您要忽略的音频,请使用该-map选项覆盖默认的流选择行为:

ffmpeg -f lavfi -i anullsrc -i video.mov -shortest -c:v copy -c:a aac \
  -map 0:a -map 1:v output.mov
Run Code Online (Sandbox Code Playgroud)
  • -map 0:a -map 1:v可以翻译为:从第一个输入(0)使用audio(a),从第二个输入(1)使用视频(v).

笔记

  • 这些示例将流复制视频,以便不会重新编码(如"复制和粘贴").

  • 始终建议使用最近的ffmpeg.最近版本的链接在FFmpeg下载页面上,或者您可以参考编译的ffmpeg分步指南.

  • 如果您ffmpeg年纪大了,那么您将需要-strict experimental使用-c:a aac.

  • `/dev/zero` 也适用于 `avconv`,但 `-f lavfi` 似乎不适用。不要忘记 `-shortest` 标志,否则它会永远坐在那里编码沉默。 (2认同)

PAS*_*LoD 15

如果其他人通过"搜索引擎"来到这里,这里是最新ffmpeg的命令,适用于MP4(H264/AVC):

ffmpeg -f lavfi -i aevalsrc = 0 -i input.mp4 -vcodec copy -acodec aac -map 0:0 -map 1:0 -shortest -strict experimental -y out.mp4

  • 如果我想添加音频不可用的无声音频怎么办? (3认同)

小智 6

从图像创建视频或将图像转换为视频,然后使用 ffmpeg 添加静默音频。

您可以在 ffmpeg 中使用 anullsrc 音频源过滤器。从图像制作 5.1 声道、48000 Hz 采样率、10 秒无声视频文件的示例:

ffmpeg -loop 1 -i img002.jpg -f lavfi -i anullsrc=channel_layout=5.1:sample_rate=48000 -t 10 -c:v libx264 -t 10 -pix_fmt yuv420p -vf scale=480:320 -y output.mp4
Run Code Online (Sandbox Code Playgroud)

img002.jpg:输入图片文件

-i anullsrc:添加静音音频

-t 10:秒数

scale=480:320:视频分辨率宽度=420,高度=320

-y:覆盖现有的输出文件

output.mp4:输出文件


小智 5

到目前为止我发现的 ffmpeg ver > 4.2 最简单的方法:

在开头添加静音:

ffmpeg -i audio_in.wav -af areverse,apad=pad_dur=1s,areverse audio_out.wav
Run Code Online (Sandbox Code Playgroud)

最后添加静音:

ffmpeg -i audio_in.wav -af apad=pad_dur=1s audio_out.wav
Run Code Online (Sandbox Code Playgroud)

这将为音频添加 1 秒的静音。