ANMERKUNG DES AUTORS
Ich nutze dieses Projekt nicht mehr und biete keine Unterstützung mehr dafür an. Wenn Sie es pflegen möchten, rufen Sie mich hier an: [email protected].
Dieses Projekt wurde vor 4 Jahren erstellt. Möglicherweise gibt es jetzt bessere Möglichkeiten, ein Video in ein GIF umzuwandeln. Verwenden Sie Google!
/ANMERKUNG DES AUTORS
Konvertieren Sie jede Videodatei in ein optimiertes animiertes GIF. Entweder in voller Länge oder nur in einem Teil davon.
Dieser Screencast wurde mit lolilolicon/FFcast aufgenommen und dann in ein GIF konvertiert mit:
gifify screencast.mkv -o screencast.gif --resize 800:-1
stdin
und stdout
Bevor Sie gifify verwenden, installieren Sie bitte:
$ brew install node
)$ brew install ffmpeg
)$ brew install imagemagick
).$ brew install giflossy
)Sie können auch das gifify Docker-Image verwenden, das mit allen installierten Komponenten geliefert wird.
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
Siehe das Beispiel.
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 ) ;
Sie können auch einen lesbaren Stream an gifify(stream, opts)
übergeben.
Gifify unterstützt Streams sowohl auf der Befehlszeile ( cat movie.mp4 | gifify -o out.gif
) als auch in der programmatischen API ( gifify(readableStream, opts).pipe(writableStream)
).
Während es in manchen Fällen sehr nützlich ist, ist es besser, gifify movie.mp4 -o out.gif
oder gifify(filePath, opts).pipe(writableStream)
zu verwenden, wenn Sie die Datei bereits auf der Festplatte haben.
Warum? Denn das Weiterleiten von 3,4 GB, wenn Sie von 40:20 auf 40:22 reduzieren möchten, nimmt immer noch viel Zeit in Anspruch und bringt Ihnen keinen Leistungsvorteil.
FFmpeg muss von 0 GB -> $START_BYTE_40:20 lesen und verwirft es. Aber alles fließt in deiner Erinnerung.
Wenn Sie die direkte Dateieingabe über die Befehlszeile verwenden, übergeben wir die Dateinamenoption -i filename
an FFmpeg und dann geht es superschnell!
Seien Sie beim |piping
vorsichtig.
Sie können einfachen Text in Ihr GIF brennen:
gifify back.mp4 -o back.gif --from 01:48:23.200 --to 01:48:25.300 --text " What?..What?What? "
Ergebnis:
Sie können Untertitel in Ihr GIF brennen, so einfach ist das:
gifify 22.mkv -o movie.gif --subtitles 22.ass --from 1995 --to 2002 --resize 600:-1
Sie müssen neue Untertiteldateien erstellen, da die Timecodes für den gesamten Film bei einem Fünf-Sekunden-GIF nicht funktionieren.
Erstellen Sie Untertitel mit aegisub und erhöhen Sie die Schriftgröße für einen tollen Effekt!
Hier ist die 22.ass
aus dem vorherigen Befehl, erstellt mit 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.
Ergebnis beim Extrahieren eines GIF aus 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/efficient-gifs#sec44
YOLO!
Giflossy ist ein Fork von Gifsicle. Der Gifsicle-Autor arbeitet derzeit daran, den verlustbehafteten Teil in Gifsicle zu integrieren.
So werden wir in kurzer Zeit in der Lage sein, Gifsicle- und Gifiscle-Pakete direkt zu verwenden.
jclem/gifify war eine großartige Inspirationsquelle.