如何将多个音频文件嵌入到具有时间线偏移的一个视频文件中?

如何将多个音频文件嵌入到具有时间线偏移的一个视频文件中?

我有一个视频文件:

screencast.mpg (100sec)

以及几个音频文件(文件名表示偏移量):

10.wav (10sec)
30.wav (5sec)
45.wav (8sec)

我如何才能将这些文件合并在一起:

V:||||||||||||||||||||||||||||||||||||||||||||||||||
A:    .....     ...     ....

我想编写一个脚本来自动完成这项工作。
我尝试过ffmpeg -itsoffset这个选项,但失败了。

答案1

以下代码假设您的.wav文件为4800 Hzstereo
它根据上述值构建静音段。
它生成单个.wav。可与视频混合。

nrChannels=2
sampleRate=48000

rawSilence() {
  local nrSeconds=$1
  local sampleRate=$2
  local nrChannels=${3:-2}
  ffmpeg -acodec pcm_s16le \
         -ar $sampleRate \
         -ac $nrChannels \
         -f s16le \
         -i <(dd if=/dev/zero bs=$((sampleRate*2*nrChannels)) count=$nrSeconds) \
         -f s16le -
}

{ 
  rawSilence 10 $sampleRate $nrChannels 
  cat "10.wav" |ffmpeg -f wav -i - -f s16le -
  rawSilence 10 $sampleRate $nrChannels
  cat "30.wav" |ffmpeg -f wav -i - -f s16le -
  rawSilence 10 $sampleRate $nrChannels
  cat "45.wav" |ffmpeg -f wav -i - -f s16le -
  rawSilence 47 $sampleRate $nrChannels
} |
  ffmpeg -acodec pcm_s16le \
         -ar $sampleRate \
         -ac $nrChannels \
         -f s16le \
         -i - \
         -f wav -y 100sec.wav

要将视频和音频混合在一起,可以使用以下或某些编码变体来实现:

ffmpeg -i "100sec.mpg" \
       -i "100sec.wav" \
          -vcodec copy \
 -y "100sec.muxed.mpg"

相关内容