gtk-recordmydesktop
スクリーンキャスティングプログラムでOGVビデオを作成し、X上のブルートフォースでこの問題に取り組みました。VLCでビデオを見ることができます。
ここでのタスクは、OGVビデオをGIFアニメーションに変換してSEで表示できるようにする方法を見つけることです。どうやってやるの?
gtk-recordmydesktop
スクリーンキャスティングプログラムでOGVビデオを作成し、X上のブルートフォースでこの問題に取り組みました。VLCでビデオを見ることができます。
ここでのタスクは、OGVビデオをGIFアニメーションに変換してSEで表示できるようにする方法を見つけることです。どうやってやるの?
回答:
これを見てください:https : //askubuntu.com/questions/107726/how-to-create-animated-gif-images-of-a-screencast/107735#107735
..... デスクトップレコーダーが記録をOGVビデオに保存した後、MPlayerを使用してJPEGスクリーンショットをキャプチャし、「出力」ディレクトリに保存します。
ターミナルで:
mplayer -ao null <video file name> -vo jpeg:outdir=output
使用ImageMagickのアニメーションGIFをにスクリーンショットを変換します。
convert output/* output.gif
この方法でスクリーンショットを最適化できます。
convert output.gif -fuzz 10% -layers Optimize optimised.gif
-limit map 1
コマンドに追加しても修正されませんでした。
ffmpeg -i output/00000%03d.jpg output.gif
unix.stackexchange.com/questions/24014/
convert output/* -fuzz 10% -layers Optimize optimised.gif
も可能であり、2つのコマンドパスよりも著しく高速であることは言及されています。また、スクリーンショットもmplayer
簡単に作成png
できます。これは、WebサイトまたはGUIのキャプチャに適している場合があります。
質の良いシンプルなスクリプト
スクリプト:
inputFile=$1
FPS=15
WIDTH=320
#Generate palette for better quality
ffmpeg -i $inputFile -vf fps=$FPS,scale=$WIDTH:-1:flags=lanczos,palettegen tmp_palette.png
#Generate gif using palette
ffmpeg -i $inputFile -i tmp_palette.png -loop 0 -filter_complex "fps=$FPS,scale=$WIDTH:-1:flags=lanczos[x];[x][1:v]paletteuse" output.gif
rm tmp_palette.png
コード:https : //superuser.com/a/556031/295664
パレットなし:(231 KB)
付パレット:(573キロバイト)
ifile=~/test.ogv
echo '# Determine input WxH and FPS'
eval "$(ffmpeg -i "$ifile" 2>&1 |sed -nr 's/.*Stream.*Video.* ([0-9]+x[0-9]+),.*[^[0-9.]([0-9.]+).*tbr,.*/WxH=\1;FPS=\2/p')"
echo '# Output multiple images from the input video'
ffmpeg -i "$ifile" -r $FPS -s $WxH -f image2 -vframes 100 -y ~/test-%03d.jpg 2>/dev/null
echo '# use ImageMagic "convert" to generate the animated .gif'
convert -delay 20 ~/test-[0-9][0-9][0-9].jpg ~/test.gif
echo '# remove temp image files'
rm -f ~/test-[0-9][0-9][0-9].jpg
echo 'Done!'
-limit map 1
変換するために追加する必要がありました(それ以外の場合は "Killed"になりました)。