NOTA DO AUTOR
Não estou mais usando este projeto nem fornecendo qualquer suporte para ele, se você quiser mantê-lo, envie-me um ping aqui: [email protected].
Este projeto foi criado há 4 anos, talvez existam maneiras melhores de transformar um vídeo em GIF agora, use o google!
/NOTA DO AUTOR
Converta qualquer arquivo de vídeo em um GIF animado otimizado. Seja em todo o seu comprimento ou apenas em parte dele.
Este screencast foi gravado com lolilolicon/FFcast e depois convertido para um GIF com:
gifify screencast.mkv -o screencast.gif --resize 800:-1
stdin
e stdout
Antes de usar o gifify, instale:
$ brew install node
)$ brew install ffmpeg
)$ brew install imagemagick
)$ brew install giflossy
)Você também pode usar a imagem gifify Docker que vem com tudo instalado.
npm install -g gifify
> gifify -h
Usage: gifify [options] [file]
Options:
-h, --help output usage information
-V, --version output the version number
--colors < n > Number of colors, up to 255, defaults to 80
--compress < n > Compression (quality) level, from 0 (no compression) to 100, defaults to 40
--from < position > Start position, hh:mm:ss or seconds, defaults to 0
--fps < n > Frames Per Second, defaults to 10
-o, --output < file > Output file, defaults to stdout
--resize < W:H > Resize output, use -1 when specifying only width or height. ` 350:100 ` , ` 400:-1 ` , ` -1:200 `
--reverse Reverses movie
--speed < n > Movie speed, defaults to 1
--subtitles < filepath > Subtitle filepath to burn to the GIF
--text < string > Add some text at the bottom of the movie
--to < position > End position, hh:mm:ss or seconds, defaults to end of movie
--no-loop Will show every frame once without looping
Veja o exemplo.
var fs = require ( 'fs' ) ;
var gifify = require ( 'gifify' ) ;
var path = require ( 'path' ) ;
var input = path . join ( __dirname , 'movie.mp4' ) ;
var output = path . join ( __dirname , 'movie.gif' ) ;
var gif = fs . createWriteStream ( output ) ;
var options = {
resize : '200:-1' ,
from : 30 ,
to : 35
} ;
gifify ( input , options ) . pipe ( gif ) ;
Você também pode passar um stream legível para gifify(stream, opts)
.
Gifify oferece suporte a streams na linha de comando ( cat movie.mp4 | gifify -o out.gif
) e na API programática ( gifify(readableStream, opts).pipe(writableStream)
).
Embora seja muito útil em alguns casos, se você já tiver o arquivo no disco, é melhor fazer gifify movie.mp4 -o out.gif
ou gifify(filePath, opts).pipe(writableStream)
.
Por que? Porque canalizar 3,4 GB quando você deseja cortar de 40:20 para 40:22 ainda leva muuuuito tempo e não oferece nenhum benefício de desempenho.
O FFmpeg deve ler 0GB -> $START_BYTE_40:20 e descarta-lo. Mas tudo flui na sua memória.
Ao usar a entrada direta de arquivo na linha de comando, passamos a opção -i filename
para o FFmpeg e então é super rápido!
Tenha cuidado ao |piping
.
Você pode gravar algum texto simples em seu GIF:
gifify back.mp4 -o back.gif --from 01:48:23.200 --to 01:48:25.300 --text " What?..What?What? "
Resultado:
Você pode gravar legendas em seu GIF, é muito fácil:
gifify 22.mkv -o movie.gif --subtitles 22.ass --from 1995 --to 2002 --resize 600:-1
Você deve criar novos arquivos de legendas, os códigos de tempo do filme completo não funcionarão para um GIF de cinco segundos.
Crie legendas usando aegisub e aumente o tamanho da fonte para obter um ótimo efeito!
Aqui está o 22.ass
do comando anterior, criado com aegisub:
[Script Info]
; Script generated by Aegisub 3.2.1
; http://www.aegisub.org/
Title: Default Aegisub file
ScriptType: v4.00+
WrapStyle: 0
ScaledBorderAndShadow: yes
YCbCr Matrix: None
[Aegisub Project Garbage]
[V4+ Styles]
Format: Name, Fontname, Fontsize, PrimaryColour, SecondaryColour, OutlineColour, BackColour, Bold, Italic, Underline, StrikeOut, ScaleX, ScaleY, Spacing, Angle, BorderStyle, Outline, Shadow, Alignment, MarginL, MarginR, MarginV, Encoding
Style: Default,Arial,20,&H00FFFFFF,&H000000FF,&H00000000,&H00000000,0,0,0,0,100,100,0,0,1,2,2,2,10,10,10,1
[Events]
Format: Layer, Start, End, Style, Name, MarginL, MarginR, MarginV, Effect, Text
Dialogue: 0,0:00:02.50,0:00:03.97,Default,,0,0,0,,{fnLiberation Sansfs40}Okay, okay.
Dialogue: 0,0:00:05.00,0:00:06.90,Default,,0,0,0,,{fnLiberation Sansfs40}Okay. Okay.
Resultado da extração de um GIF de 22 Jump Street:
On modern hardware GIF is the slowest and most expensive video codec. Can we please allow it to be obsoleted?
https://pornel.net/eficiente-gifs#sec44
YOLO!
Giflossy é um fork do gifsicle, o autor do gifsicle está atualmente trabalhando na integração da parte com perdas no gifsicle.
Assim, em pouco tempo poderemos usar diretamente os pacotes gifsicle e gifiscle.
jclem/gifify foi uma grande fonte de inspiração.