Crie vídeo a partir de imagens e áudio com durações de imagem variadas usando o FFMPEG?

0

O que eu quero fazer:

Eu tenho x quantidade de imagens png / jpg, e quero mostrá-las por duração variável, por mais tempo e por um tempo menor.

  • a1.jpg A primeira foto permanece por 3 segundos
  • a2.png permanece por 10 segundos
  • a3.jpg fica até o final do áudio

O vídeo deve ser tão longo quanto o audio.mp3

este é o meu código até agora depois de ler a documentação, não tenho certeza do que está errado, recebo vídeo corrompido sem som e só mostra a última imagem.

Também gostaria de centralizar as imagens, se possível.

ffmpeg -y \
  -loop 1 -t 1 -i a1.jpg \
  -loop 1 -t 1 -i a2.jpg \
  -loop 1 -t 4 -i a3.jpg \
  -loop 1 -t 1 -i a4.png \
  -loop 1 -t 1 -i a5.png \
  -i audio.mp3 \
  -c:v libx264 -pix_fmt yuv420p -c:a copy video.mp4

tente

ffmpeg -y -framerate 15 \
  -loop 1 -t 1 -i a1.jpg \
  -loop 1 -t 1 -i a2.jpg \
  -loop 1 -t 4 -i a3.jpg \
  -loop 1 -t 1 -i a4.png \
  -loop 1 -t 1 -i a5.png \
  -i audio.mp3 \
  -c:v libx264 -pix_fmt yuv420p -c:a copy \
  -filter_complex " \
  [0]setdar=16/9[a1],[a1]scale=720x406[a];[1]setdar=16/9[b1],[b1]scale=720x406[b];[2]setdar=16/9[c1],[c1]scale=720x406[c];[3]setdar=16/9[d1],[d1]scale=720x406[d];[4]setdar=16/9[e1],[e1]scale=720x406[e]; 
  [a][b][c][d][e]concat=n=5,format=yuv420p[v],[v]scale=720x406[v1],[v1]setdar=16/9[v2]" \
  -map "[v2]" -c:a copy out.mp4
    
por Muhammad Umer 08.01.2018 / 23:24

1 resposta

2

Modelo básico é

ffmpeg -y \
  -loop 1 -t 1 -i a1.jpg \
  -loop 1 -t 1 -i a2.jpg \
  -loop 1 -t 4 -i a3.jpg \
  -loop 1 -t 1 -i a4.png \
  -loop 1 -i a5.png \
  -i audio.mp3 \
  -filter_complex "concat=n=5" -shortest \
  -c:v libx264 -pix_fmt yuv420p -c:a aac video.mp4

A especificação t para cada imagem define sua duração. O t da última imagem deve ser omitido se você quiser que o vídeo dure até que o áudio termine.

Eu uso o filtro de concatenação para unir todas as entradas de vídeo. A boa prática é rotular quais entradas o filtro de concat será incluído, mas se não for especificado, o filtro capturará as primeiras N -i entradas, em que N é o valor definido no filtro de concat. Todas as imagens devem ter a mesma resolução e proporção.

Seu comando determinado copia o áudio, mas o MP3, apesar de permitido, não é padrão no MP4, e alguns players, como o Quicktime, não reproduzem o arquivo, então eu mudei para o AAC.

Para imagens de tamanhos diferentes, altere o filter_complex para

"[0]scale=W:H:force_original_aspect_ratio=decrease,pad=W:H:(ow-iw)/2:(oh-ih)/2,setsar=1[i0];
 [1]scale=W:H:force_original_aspect_ratio=decrease,pad=W:H:(ow-iw)/2:(oh-ih)/2,setsar=1[i1];
 [2]scale=W:H:force_original_aspect_ratio=decrease,pad=W:H:(ow-iw)/2:(oh-ih)/2,setsar=1[i2];
 [3]scale=W:H:force_original_aspect_ratio=decrease,pad=W:H:(ow-iw)/2:(oh-ih)/2,setsar=1[i3];
 [4]scale=W:H:force_original_aspect_ratio=decrease,pad=W:H:(ow-iw)/2:(oh-ih)/2,setsar=1[i4];
 [i0][i1][i2][i3][i4]concat=n=5"

W e H devem ser substituídos por valores numéricos de largura e altura do vídeo alvo.

    
por 09.01.2018 / 07:36