-pattern_type glob
この優れたオプションにより、多くの場合、イメージを選択しやすくなります。
1秒あたり1画像のスライドショービデオ
ffmpeg -framerate 1 -pattern_type glob -i '*.png' \
-c:v libx264 -r 30 -pix_fmt yuv420p out.mp4
それにいくつかの音楽を追加し、画像が終了したときにおそらくより長いオーディオのときにカットオフします。
ffmpeg -framerate 1 -pattern_type glob -i '*.png' -i audio.ogg \
-c:a copy -shortest -c:v libx264 -r 30 -pix_fmt yuv420p out.mp4
YouTubeには2つのデモがあります。
ヒッピーになり、Theoraの特許を取得していないビデオ形式を使用します。
ffmpeg -framerate 1 -pattern_type glob -i '*.png' -i audio.ogg \
-c:a copy -shortest -c:v libtheora -r 30 -pix_fmt yuv420p out.ogg
もちろん、画像はアルファベット順に、通常は次のように並べ替える必要があります。
0001-first-thing.jpg
0002-second-thing.jpg
0003-and-third.jpg
等々。
また、使用するすべての画像が同じアスペクト比であることを最初に確認します。おそらく、事前にimagemagick
またはnomacsでトリミングして、ffmpegが難しい決定をする必要がないようにします。特に、幅は2で割り切れる必要があります。そうでない場合、変換は「2で割り切れない幅」で失敗します。
30 FPSでフレームごとに1つの画像がある通常の速度のビデオ
ffmpeg -framerate 30 -pattern_type glob -i '*.png' \
-c:v libx264 -pix_fmt yuv420p out.mp4
これは次のようになります。
生成されたGIF:https : //askubuntu.com/questions/648603/how-to-create-an-animated-gif-from-mp4-video-via-command-line/837574#837574
それにオーディオを追加します。
ffmpeg -framerate 30 -pattern_type glob -i '*.png' \
-i audio.ogg -c:a copy -shortest -c:v libx264 -pix_fmt yuv420p out.mp4
結果:https : //www.youtube.com/watch?v=HG7c7lldhM4
これらは私が使用したテストメディアです:
wget -O opengl-rotating-triangle.zip https://github.com/cirosantilli/media/blob/master/opengl-rotating-triangle.zip?raw=true
unzip opengl-rotating-triangle.zip
cd opengl-rotating-triangle
wget -O audio.ogg https://upload.wikimedia.org/wikipedia/commons/7/74/Alnitaque_%26_Moon_Shot_-_EURO_%28Extended_Mix%29.ogg
で生成された画像:GLUT / OpenGLを使用してファイルにレンダリングする方法
特殊なアルゴリズムを使用してフレーム間で圧縮できるため、ビデオがZIPよりも画像シーケンスをどの程度圧縮するかを観察するのはクールです。
opengl-rotating-triangle.mp4
:340K
opengl-rotating-triangle.zip
:730万
YouTubeアップロード用に、1つの音楽ファイルを固定画像のビデオに変換します
回答済み:https : //superuser.com/questions/700419/how-to-convert-mp3-to-youtube-allowed-video-format/1472572#1472572
ステップバイステップの完全なスライドショーのケーススタディ設定
スライドショーの作成には、単一のffmpegコマンドを実行するよりも少し多いので、このタイムラインに触発されたより興味深い詳細な例を示します。
入力メディアを取得します。
mkdir -p orig
cd orig
wget -O 1.png https://upload.wikimedia.org/wikipedia/commons/2/22/Australopithecus_afarensis.png
wget -O 2.jpg https://upload.wikimedia.org/wikipedia/commons/6/61/Homo_habilis-2.JPG
wget -O 3.jpg https://upload.wikimedia.org/wikipedia/commons/c/cb/Homo_erectus_new.JPG
wget -O 4.png https://upload.wikimedia.org/wikipedia/commons/1/1f/Homo_heidelbergensis_-_forensic_facial_reconstruction-crop.png
wget -O 5.jpg https://upload.wikimedia.org/wikipedia/commons/thumb/5/5a/Sabaa_Nissan_Militiaman.jpg/450px-Sabaa_Nissan_Militiaman.jpg
wget -O audio.ogg https://upload.wikimedia.org/wikipedia/commons/7/74/Alnitaque_%26_Moon_Shot_-_EURO_%28Extended_Mix%29.ogg
cd ..
# Convert all to PNG for consistency.
# /unix/29869/converting-multiple-image-files-from-jpeg-to-pdf-format
# Hardlink the ones that are already PNG.
mkdir -p png
mogrify -format png -path png orig/*.jpg
ln -P orig/*.png png
これで、最終的なアスペクト比を決定するためにすべての画像サイズを簡単に確認できます。
identify png/*
出力:
png/1.png PNG 557x495 557x495+0+0 8-bit sRGB 653KB 0.000u 0:00.000
png/2.png PNG 664x800 664x800+0+0 8-bit sRGB 853KB 0.000u 0:00.000
png/3.png PNG 544x680 544x680+0+0 8-bit sRGB 442KB 0.000u 0:00.000
png/4.png PNG 207x238 207x238+0+0 8-bit sRGB 76.8KB 0.000u 0:00.000
png/5.png PNG 450x600 450x600+0+0 8-bit sRGB 627KB 0.000u 0:00.000
そのため、クラシックな480p(640x480 == 4/3)のアスペクト比が適切と思われます。
最小のサイズ変更で1つの変換を実行して幅を均等にします(TODOは任意の幅で自動化されます。ここでは、identify
出力を手動で見て、幅と高さを1つ減らしました)。
mkdir -p raw
convert png/1.png -resize 556x494 raw/1.png
ln -P png/2.png png/3.png png/4.png png/5.png raw
ffmpeg -framerate 1 -pattern_type glob -i 'raw/*.png' -i orig/audio.ogg -c:v libx264 -c:a copy -shortest -r 30 -pix_fmt yuv420p raw.mp4
次のように表示されるため、これはひどい出力を生成します。
ffprobe raw.mp4
ffmpegは最初の画像のサイズ556x494を取得し、他のすべての画像をその正確なサイズに変換して、縦横比を壊します。
次に、ImageMagickに従ってトリミングすることにより、画像をターゲットの480pアスペクト比に自動的に変換します。画像を特定のアスペクト比に最小限にトリミングする方法は?
mkdir -p auto
mogrify -path auto -geometry 640x480^ -gravity center -crop 640x480+0+0 png/*.png
ffmpeg -framerate 1 -pattern_type glob -i 'auto/*.png' -i orig/audio.ogg -c:v libx264 -c:a copy -shortest -r 30 -pix_fmt yuv420p auto.mp4
これでアスペクト比は良好になりましたが、必然的に一部のトリミングが必要になり、画像の興味深い部分が切り取られました。
もう1つのオプションは、次の図に示すのと同じアスペクト比になるように黒の背景を埋め込むことです。ボックスに合わせてサイズを変更し、「空の」部分の背景を黒に設定します。
mkdir -p black
ffmpeg -framerate 1 -pattern_type glob -i 'black/*.png' -i orig/audio.ogg -c:v libx264 -c:a copy -shortest -r 30 -pix_fmt yuv420p black.mp4
ただし、一般的に言えば、最初からこれらの問題を回避するために、同じまたは同様のアスペクト比の画像を選択できることが理想的です。
CLIオプションについて
名前にもかかわらず、ことに注意してください-glob
例えば、これはシェルグロブpattersとして一般的なようではありません:-i '*'
失敗:https://trac.ffmpeg.org/ticket/3620(どうやらファイルタイプは拡張子から推定されているため)。
-r 30
作る-framerate 1
:ビデオ30 FPSが低いフレームレートのためのVLCのような選手にバグを克服するためにVLCはffmpegの持つイメージから作成された低1 FPSビデオにフリーズするためには、第二の効果につき1枚の画像を希望維持するために、各フレームを30回繰り返します。
次のステップ
また、次のことも行います。
TODO:中間ファイルなしで複数のオーディオファイルをカットしてビデオに連結する方法を学びます。それが可能であると確信しています。
テスト済み
ffmpeg 3.4.4、vlc 3.0.3、Ubuntu 18.04。
参考文献