Dies ist der Befehl ffmpeg-all, der im kostenlosen OnWorks-Hosting-Provider mit einer unserer zahlreichen kostenlosen Online-Workstations wie Ubuntu Online, Fedora Online, Windows-Online-Emulator oder MAC OS-Online-Emulator ausgeführt werden kann
PROGRAMM:
NAME/FUNKTION
ffmpeg - ffmpeg-Videokonverter
ZUSAMMENFASSUNG
ffmpeg [globale_optionen] {[input_file_options] -ich Eingabedatei} ... {[Ausgabedateioptionen]
Ausgabedatei} ...
BESCHREIBUNG
ffmpeg ist ein sehr schneller Video- und Audiokonverter, der auch Live-Audio/Video aufnehmen kann
Quelle. Es kann auch zwischen beliebigen Abtastraten konvertieren und die Größe von Videos im Handumdrehen ändern
mit einem hochwertigen Polyphasenfilter.
ffmpeg liest aus einer beliebigen Anzahl von Eingabe-"Dateien" (das können normale Dateien, Pipes,
Netzwerkstreams, Greifgeräte usw.), die durch die Option "-i" angegeben werden, und schreibt in eine
beliebige Anzahl von Ausgabe-"Dateien", die durch einen einfachen Ausgabedateinamen angegeben werden.
Alles, was auf der Kommandozeile gefunden wird und nicht als Option interpretiert werden kann, wird berücksichtigt
ein Ausgabedateiname sein.
Jede Eingabe- oder Ausgabedatei kann prinzipiell beliebig viele Streams unterschiedlicher
Typen (Video/Audio/Untertitel/Anhang/Daten). Die zulässige Anzahl und/oder Arten von Streams
kann durch das Containerformat eingeschränkt sein. Auswählen, welche Streams von welchen Eingängen gehen
in die die Ausgabe entweder automatisch oder mit der Option "-map" erfolgt (siehe Stream
Auswahlkapitel).
Um in Optionen auf Eingabedateien zu verweisen, müssen Sie deren Indizes verwenden (0-basiert). ZB der erste
Eingabedatei ist 0, die zweite ist 1, usw. In ähnlicher Weise werden Streams innerhalb einer Datei mit bezeichnet
ihre Indizes. ZB "2:3" bezieht sich auf den vierten Stream in der dritten Eingabedatei. Siehe auch
das Kapitel Stream-Bezeichner.
In der Regel werden Optionen auf die nächste angegebene Datei angewendet. Daher ist die Ordnung
wichtig, und Sie können dieselbe Option mehrmals in der Befehlszeile verwenden. Jeder
Das Vorkommen wird dann auf die nächste Eingabe- oder Ausgabedatei angewendet. Ausnahmen von dieser Regel
sind die globalen Optionen (zB Ausführlichkeitsstufe), die zuerst angegeben werden sollten.
Mischen Sie keine Eingabe- und Ausgabedateien – geben Sie zuerst alle Eingabedateien und dann alle Ausgabedateien an.
Mischen Sie auch keine Optionen, die zu verschiedenen Dateien gehören. Alle Optionen gelten NUR für die
nächste Eingabe- oder Ausgabedatei und werden zwischen den Dateien zurückgesetzt.
· So stellen Sie die Videobitrate der Ausgabedatei auf 64 kbit/s ein:
ffmpeg -i Eingabe.avi -b:v 64k -bufsize 64k Ausgabe.avi
· So erzwingen Sie die Bildrate der Ausgabedatei auf 24 fps:
ffmpeg -i Eingabe.avi -r 24 Ausgabe.avi
· Um die Bildrate der Eingabedatei (nur gültig für Rohformate) auf 1 fps zu erzwingen und
die Bildrate der Ausgabedatei auf 24 fps:
ffmpeg -r 1 -i Eingabe.m2v -r 24 Ausgabe.avi
Die Formatoption wird möglicherweise für Roheingabedateien benötigt.
DETAILLIERTE BESCHREIBUNG
Der Transcodierungsprozess in ffmpeg für jeden Ausgang kann wie folgt beschrieben werden
Diagramm:
_______ ______________
| | | |
| Eingabe | demuxer | codierte Daten | Decoder
| Datei | -------> | Pakete | -----+
|_______| |______________| |
v
_________
| |
| entschlüsselt |
| Rahmen |
| _________ |
________ ______________ |
| | | | |
| Ausgabe | <-------- | codierte Daten | <----+
| Datei | Muxer | Pakete | Encoder
|________| |______________|
ffmpeg ruft die Bibliothek libavformat (die Demuxer enthält) auf, um Eingabedateien zu lesen und zu erhalten
Pakete, die codierte Daten von ihnen enthalten. Wenn mehrere Eingabedateien vorhanden sind, ffmpeg
versucht, sie synchronisiert zu halten, indem der niedrigste Zeitstempel in jedem aktiven Eingabestream verfolgt wird.
Codierte Pakete werden dann an den Decoder übergeben (es sei denn, streamcopy wird für die
Stream, siehe weiter für eine Beschreibung). Der Decoder erzeugt unkomprimierte Frames (raw
Video/PCM-Audio/...), die durch Filterung weiterverarbeitet werden können (siehe nächster Abschnitt). Nach
Filterung werden die Frames an den Encoder übergeben, der sie kodiert und kodiert ausgibt
Pakete. Schließlich werden diese an den Muxer übergeben, der die codierten Pakete in die
Ausgabedatei.
Filterung
Vor dem Codieren, ffmpeg kann rohe Audio- und Videoframes mit Filtern aus dem
libavfilter-Bibliothek. Mehrere verkettete Filter bilden einen Filtergraphen. ffmpeg unterscheidet
zwischen zwei Arten von Filtergraphen: einfach und komplex.
Einfacher Filtergrafiken
Einfache Filtergraphen sind solche, die genau einen Eingang und Ausgang haben, beide gleich
Typ. Im obigen Diagramm können sie durch einfaches Einfügen eines zusätzlichen Schrittes dargestellt werden
zwischen Dekodierung und Kodierung:
_________ ______________
| | | |
| entschlüsselt | | kodierte Daten |
| Rahmen |\ _ | Pakete |
|__________| \ /||______________|
\ __________ /
einfach _\|| | / Encoder
Filtergrafik | gefiltert |/
| Rahmen |
|__________|
Einfache Filtergraphen werden mit dem Per-Stream konfiguriert -Filter Option (mit -vf und -N
Aliase für Video bzw. Audio). Ein einfacher Filtergraph für Video kann gesucht werden
Beispiel wie folgt:
_______ _____________ _______ ________
| | | | | | | |
| Eingabe | ---> | deinterlacen | ---> | Skala | ---> | Ausgabe |
|_______| |______________| |_______| |________|
Beachten Sie, dass einige Filter die Frame-Eigenschaften ändern, aber nicht den Frame-Inhalt. zB die "fps"
Filter im obigen Beispiel ändert die Anzahl der Frames, berührt aber nicht den Frame
Inhalt. Ein weiteres Beispiel ist der Filter "setpts", der nur Zeitstempel setzt und sonst
übergibt die Frames unverändert.
Complex Filtergrafiken
Komplexe Filtergraphen sind solche, die nicht einfach als lineare Verarbeitung beschrieben werden können
Kette auf einen Stream angewendet. Dies ist zum Beispiel der Fall, wenn der Graph mehr als
eine Eingabe und/oder Ausgabe, oder wenn der Ausgabestromtyp sich von der Eingabe unterscheidet. Sie können sein
dargestellt mit folgendem Diagramm:
_________
| |
| Eingabe 0 |\ __________
|__________| \ | |
\ _________ /| Ausgang 0 |
\ | | / |__________|
_________ \| komplex | /
| | | |/
| Eingang 1 |---->| filtern |\
|__________| | | \ __________
/| Grafik | \ | |
/ | | \| Ausgang 1 |
_________ / |_________| |__________|
| | /
| Eingang 2 |/
| _________ |
Komplexe Filtergraphen werden mit dem -filter_komplex Möglichkeit. Beachten Sie, dass dies
Option ist global, da ein komplexer Filtergraph naturgemäß nicht eindeutig sein kann
einem einzelnen Stream oder einer Datei zugeordnet.
Die -lavfi Option ist äquivalent zu -filter_komplex.
Ein triviales Beispiel für einen komplexen Filtergraph ist der "Overlay"-Filter, der zwei Video
Eingänge und einen Videoausgang, der ein Video über das andere enthält. Sein Audio
Gegenstück ist der "amix"-Filter.
Strom Kopieren
Stream Copy ist ein Modus, der ausgewählt wird, indem der Parameter "copy" an die -Codec Möglichkeit. Es
macht ffmpeg Lassen Sie den Decodierungs- und Codierungsschritt für den angegebenen Stream aus, sodass dies nur der Fall ist
demuxen und muxen. Es ist nützlich, um das Containerformat zu ändern oder zu ändern
Metadaten auf Containerebene. Das obige Diagramm vereinfacht sich in diesem Fall so:
_______ ______________ ________
| | | | | |
| Eingabe | demuxer | kodierte Daten | Muxer | Ausgabe |
| Datei | -------> | Pakete | -------> | Datei |
|_______| |______________| |________|
Da keine Dekodierung oder Kodierung stattfindet, ist es sehr schnell und es gibt keinen Qualitätsverlust.
In einigen Fällen kann es jedoch aufgrund vieler Faktoren nicht funktionieren. Das Anwenden von Filtern ist
offensichtlich auch unmöglich, da Filter auf unkomprimierte Daten arbeiten.
STREAM SELECTION
Standardmäßig ffmpeg enthält nur einen Stream jedes Typs (Video, Audio, Untertitel) vorhanden
in den Eingabedateien und fügt sie jeder Ausgabedatei hinzu. Es wählt das "Beste" von jeder Basis aus
nach folgenden Kriterien: für Video der Stream mit der höchsten Auflösung, für
Audio, es ist der Stream mit den meisten Kanälen, für Untertitel ist es der erste Untertitel
Strom. Für den Fall, dass mehrere Streams des gleichen Typs gleich viel bewerten, wird der Stream mit
der niedrigste Index wird gewählt.
Sie können einige dieser Standardeinstellungen deaktivieren, indem Sie die Optionen "-vn/-an/-sn" verwenden. Für vollständiges Handbuch
control verwenden Sie die Option "-map", die die gerade beschriebenen Standardeinstellungen deaktiviert.
OPTIONAL
Alle numerischen Optionen akzeptieren, wenn nicht anders angegeben, eine Zeichenfolge, die a . darstellt
Zahl als Eingabe, gefolgt von einem der SI-Einheitenpräfixe, zum Beispiel: 'K',
'M' oder 'G'.
Wenn 'i' an das SI-Einheitenpräfix angehängt wird, wird das vollständige Präfix als a . interpretiert
Einheitenpräfix für binäre Vielfache, die auf Potenzen von 1024 statt Potenzen von . basieren
1000. Das Anhängen von 'B' an das Präfix der SI-Einheit multipliziert den Wert mit 8. Dies ermöglicht die Verwendung von
zum Beispiel: 'KB', 'MiB', 'G' und 'B' als Nummernsuffixe.
Optionen, die keine Argumente annehmen, sind boolesche Optionen und setzen den entsprechenden Wert
zu wahr. Sie können auf false gesetzt werden, indem dem Optionsnamen "no" vorangestellt wird. Zum Beispiel
die Verwendung von "-nofoo" setzt die boolesche Option mit dem Namen "foo" auf false.
Strom Bezeichner
Einige Optionen werden pro Stream angewendet, zB Bitrate oder Codec. Stream-Bezeichner werden verwendet, um
Geben Sie genau an, zu welchem/n Stream(s) eine bestimmte Option gehört.
Ein Stream-Bezeichner ist eine Zeichenfolge, die im Allgemeinen an den Optionsnamen angehängt und von diesem getrennt wird
durch einen Doppelpunkt. Beispiel: "-codec:a:1 ac3" enthält den Stream-Spezifizierer "a:1", der dem
zweiten Audiostream. Daher würde es den ac3-Codec für den zweiten Audiostream auswählen.
Ein Stream-Bezeichner kann mehrere Streams zuordnen, sodass die Option auf alle angewendet wird
Sie. ZB passt der Stream-Specifier in "-b:a 128k" zu allen Audio-Streams.
Ein leerer Stream-Bezeichner stimmt mit allen Streams überein. Beispiel: "-codec copy" oder "-codec:
copy" würde alle Streams ohne Neucodierung kopieren.
Mögliche Formen von Stream-Bezeichnern sind:
stream_index
Entspricht dem Stream mit diesem Index. ZB "-threads:1 4" würde die Threadanzahl für . setzen
der zweite Stream zu 4.
stream_type[:stream_index]
stream_type ist einer der folgenden: 'v' oder 'V' für Video, 'a' für Audio, 's' für
Untertitel, 'd' für Daten und 't' für Anhänge. 'v' entspricht allen Videostreams, 'V'
Gleicht nur Videostreams ab, denen keine Bilder, Video-Thumbnails oder Cover angehängt sind
Künste. Wenn stream_index gegeben ist, dann stimmt es mit der Stream-Nummer überein stream_index von diesem
Typ. Andernfalls entspricht es allen Streams dieses Typs.
p:Programm-ID[:stream_index]
If stream_index gegeben ist, dann stimmt es mit dem Stream mit der Nummer überein stream_index begann
Programm mit der ID Programm-ID. Andernfalls entspricht es allen Streams im Programm.
#stream_id or i:stream_id
Ordnen Sie den Stream nach der Stream-ID zu (zB PID im MPEG-TS-Container).
m:Haupt[:Wert]
Gleicht Streams mit dem Metadaten-Tag ab Haupt den angegebenen Wert haben. Wenn Wert ist nicht
gegeben, ordnet Streams, die das angegebene Tag enthalten, einen beliebigen Wert zu.
u Stimmt Streams mit brauchbarer Konfiguration überein, der Codec muss definiert und das Wesentliche
Informationen wie Videodimension oder Audio-Samplerate müssen vorhanden sein.
Beachten Sie, dass in ffmpeg, funktioniert der Abgleich nach Metadaten nur für Eingabedateien richtig.
Generisch Optionen
Diese Optionen werden von den ff*-Tools gemeinsam genutzt.
-L Lizenz anzeigen.
-H, -?, -Hilfe, --help [arg]
Zeig Hilfe. Ein optionaler Parameter kann angegeben werden, um Hilfe zu einem bestimmten Element zu drucken.
Wenn kein Argument angegeben wird, werden nur grundlegende (nicht erweiterte) Werkzeugoptionen angezeigt.
Mögliche Werte von arg sind:
lange
Drucken Sie erweiterte Werkzeugoptionen zusätzlich zu den grundlegenden Werkzeugoptionen.
voller
Drucken Sie eine vollständige Liste der Optionen, einschließlich gemeinsamer und privater Optionen für Encoder,
Decoder, Demuxer, Muxer, Filter usw.
Decoder=Decodername
Drucken Sie detaillierte Informationen über den benannten Decoder Decodername. Benutze die -Decoder
Option, um eine Liste aller Decoder zu erhalten.
Encoder=Encoder_Name
Detaillierte Informationen zum benannten Encoder ausdrucken Encoder_Name. Benutze die -Encoder
Option, um eine Liste aller Encoder zu erhalten.
Demuxer=Demuxer-Name
Drucken Sie detaillierte Informationen über den benannten Demuxer Demuxer-Name. Benutze die -Formate
Option, um eine Liste aller Demuxer und Muxer zu erhalten.
muxer=muxer_name
Drucken Sie detaillierte Informationen über den genannten Muxer muxer_name. Benutze die -Formate
Option, um eine Liste aller Muxer und Demuxer zu erhalten.
Filter=Filtername
Detaillierte Informationen zum Filternamen drucken Filtername. Benutze die -Filter
Option, um eine Liste aller Filter zu erhalten.
-Ausführung
Version anzeigen.
-Formate
Verfügbare Formate anzeigen (einschließlich Geräte).
-Geräte
Verfügbare Geräte anzeigen.
-Codecs
Alle Codecs anzeigen, die libavcodec bekannt sind.
Beachten Sie, dass der Begriff 'Codec' in dieser Dokumentation als Abkürzung für
was richtiger ein Medien-Bitstream-Format genannt wird.
-Decoder
Verfügbare Decoder anzeigen.
-Encoder
Alle verfügbaren Encoder anzeigen.
-bsfs
Verfügbare Bitstream-Filter anzeigen.
-Protokolle
Verfügbare Protokolle anzeigen.
-Filter
Verfügbare libavfilter-Filter anzeigen.
-pix_fmts
Verfügbare Pixelformate anzeigen.
-sample_fmts
Verfügbare Beispielformate anzeigen.
-Layouts
Kanalnamen und Standardkanallayouts anzeigen.
-Farben
Erkannte Farbnamen anzeigen.
-quellen Gerät[,opt1=val1[,opt2=val2]...]
Zeigt automatisch erkannte Quellen des Eingabegeräts an. Einige Geräte können system-
abhängige Quellennamen, die nicht automatisch erkannt werden können. Die zurückgegebene Liste kann nicht sein
als immer vollständig angenommen.
ffmpeg -sources puls,server=192.168.0.4
-senkt Gerät[,opt1=val1[,opt2=val2]...]
Automatisch erkannte Senken des Ausgabegeräts anzeigen. Einige Geräte können system-
abhängige Senkennamen, die nicht automatisch erkannt werden können. Die zurückgegebene Liste kann nicht angenommen werden
immer vollständig zu sein.
ffmpeg -senkt Impuls, Server=192.168.0.4
-Loglevel [wiederholen+]loglevel | -v [wiederholen+]loglevel
Legen Sie die von der Bibliothek verwendete Protokollierungsebene fest. Das Hinzufügen von "repeat+" zeigt an, dass wiederholt
log-Ausgabe sollte nicht auf die erste Zeile komprimiert werden und die "Letzte Nachricht wiederholt n
times" wird ausgelassen. "repeat" kann auch alleine verwendet werden. Wenn "repeat" verwendet wird
allein und ohne vorheriges gesetztes Loglevel wird das Standard-Loglevel verwendet. Wenn mehrere
Loglevel-Parameter angegeben sind, wird die Verwendung von 'repeat' den Loglevel nicht ändern. loglevel
ist ein String oder eine Zahl mit einem der folgenden Werte:
ruhig, -8
Zeigen Sie überhaupt nichts; Schweigen.
Panik, 0
Zeigen Sie nur schwerwiegende Fehler an, die zum Absturz des Prozesses führen könnten, wie und assert
Versagen. Dies wird derzeit für nichts verwendet.
tödlich, 8
Nur schwerwiegende Fehler anzeigen. Dies sind Fehler, nach denen der Prozess absolut nicht mehr möglich ist
weiter nach.
Error, 16
Zeigen Sie alle Fehler an, einschließlich derer, die wiederhergestellt werden können.
Warnung, 24
Alle Warnungen und Fehler anzeigen. Jede Nachricht im Zusammenhang mit möglicherweise falschen oder
unerwartete Ereignisse werden angezeigt.
Info, 32
Zeigen Sie während der Verarbeitung informative Meldungen an. Dies ist zusätzlich zu Warnungen und
Fehler. Dies ist der Standardwert.
ausführlich, 40
Wie "info", nur ausführlicher.
debuggen, 48
Alles anzeigen, einschließlich Debugging-Informationen.
verfolgen, 56
Standardmäßig loggt sich das Programm in stderr ein, wenn die Farbgebung vom Terminal unterstützt wird,
Farben werden verwendet, um Fehler und Warnungen zu markieren. Die Färbung des Protokolls kann deaktiviert werden, indem die
variable Umgebung AV_LOG_FORCE_NOCOLOR or KEINE FARBE, oder kann erzwungenes Einstellen der
variable Umgebung AV_LOG_FORCE_COLOR. Die Verwendung der Umgebungsvariablen KEINE FARBE
ist veraltet und wird in einer folgenden FFmpeg-Version entfernt.
-Bericht
Vollständige Befehlszeilen- und Konsolenausgabe in eine Datei namens . ausgeben
"Programm-JJJJMMTT-HHMMSS.log" im aktuellen Verzeichnis. Diese Datei kann nützlich sein für
Fehlerberichte. Es impliziert auch "-loglevel verbose".
Umgebungsvariable setzen FREPORT auf einen beliebigen Wert hat den gleichen Effekt. Wenn die
value ist eine durch ':' getrennte Schlüssel=Wert-Sequenz, diese Optionen wirken sich auf den Bericht aus;
Optionswerte müssen mit Escapezeichen versehen werden, wenn sie Sonderzeichen oder die Optionen enthalten
Trennzeichen ':' (siehe den Abschnitt ``Quoting and Escaping'' im ffmpeg-utils-Handbuch).
Folgende Optionen werden erkannt:
Datei
Legen Sie den Dateinamen fest, der für den Bericht verwendet werden soll; %p wird zum Namen des . erweitert
Programm, %t wird zu einem Zeitstempel erweitert, "%%" wird zu einem einfachen "%" erweitert
Grad des
Setzen Sie den Log Ausführlichkeitsgrad mit einem numerischen Wert (siehe "-loglevel").
Um beispielsweise einen Bericht in eine Datei namens . auszugeben ffreport.log mit einem Log-Level von 32
(Alias für Loglevel "info"):
FFREPORT=file=ffreport.log:level=32 ffmpeg -i Eingabe Ausgabe
Fehler beim Parsen der Umgebungsvariablen sind nicht schwerwiegend und werden nicht in der Datei angezeigt
berichten.
-Banner ausblenden
Druckbanner unterdrücken.
Alle FFmpeg-Tools zeigen normalerweise einen Copyright-Hinweis, Build-Optionen und eine Bibliothek an
Versionen. Diese Option kann verwendet werden, um das Drucken dieser Informationen zu unterdrücken.
-CPU-Flags Fahnen (globale )
Ermöglicht das Setzen und Löschen von CPU-Flags. Diese Option ist zum Testen gedacht. Verwende nicht
es sei denn, Sie wissen, was Sie tun.
ffmpeg -cpuflags -sse+mmx ...
ffmpeg -cpuflags mmx ...
ffmpeg -cpuflags 0 ...
Mögliche Flags für diese Option sind:
x86
MMX
mmext
sse
ss2
sse2langsam
ss3
sse3langsam
ssse3
Atom
ss4.1
ss4.2
avx
avx2
xop
fma3
fma4
3djetzt
3dnowext
bmi1
bmi2
cmov
ARM
armv5te
armv6
armv6t2
vfp
vfpv3
Neon
setzen
AAArch64
armv8
vfp
Neon
PowerPC
altivec
spezifische Prozessoren
Pentium2
Pentium3
Pentium4
k6
k62
athlon
athlonxp
k8
-opencl_bench
Diese Option wird verwendet, um alle verfügbaren OpenCL-Geräte zu vergleichen und die Ergebnisse zu drucken.
Diese Option ist nur verfügbar, wenn FFmpeg mit "--enable-opencl" kompiliert wurde.
Wenn FFmpeg mit "--enable-opencl" konfiguriert ist, werden die Optionen für die globale OpenCL
Kontext werden gesetzt über -opencl_options. Siehe den Abschnitt "OpenCL-Optionen" im ffmpeg-
utils-Handbuch für die vollständige Liste der unterstützten Optionen. Unter anderem diese Optionen
beinhalten die Möglichkeit, eine bestimmte Plattform und ein bestimmtes Gerät auszuwählen, um den OpenCL-Code auszuführen
An. Standardmäßig wird FFmpeg auf dem ersten Gerät der ersten Plattform ausgeführt. Während
Optionen für den globalen OpenCL-Kontext bieten dem Benutzer Flexibilität bei der Auswahl der
OpenCL-Gerät ihrer Wahl, die meisten Benutzer möchten wahrscheinlich das schnellste auswählen
OpenCL-Gerät für ihr System.
Diese Option unterstützt die Auswahl der effizientesten Konfiguration, indem sie
das passende Gerät für das System des Benutzers. Der eingebaute Benchmark wird auf allen
OpenCL-Geräte und die Leistung wird für jedes Gerät gemessen. Die Geräte im
Die Ergebnisliste wird nach Leistung sortiert, wobei das schnellste Gerät aufgelistet wird
Erste. Der Benutzer kann anschließend aufrufen ffmpeg mit dem Gerät, das als am meisten angesehen wird
passend über -opencl_options um die beste Leistung für die OpenCL zu erzielen
beschleunigter Code.
Die typische Verwendung des schnellsten OpenCL-Geräts umfasst die folgenden Schritte.
Führen Sie den Befehl aus:
ffmpeg -opencl_bench
Notieren Sie sich die Plattform-ID (pidx) und Geräte-ID (didx) des ersten bzw. schnellsten Geräts
In der Liste. Wählen Sie die Plattform und das Gerät mit dem Befehl aus:
ffmpeg -opencl_options platform_idx= :device_idx= ...
-opencl_options Optionen (globale )
Legen Sie OpenCL-Umgebungsoptionen fest. Diese Option ist nur verfügbar, wenn FFmpeg
kompiliert mit "--enable-opencl".
Optionen muss eine Liste von sein Haupt=Wert Optionspaare durch ':' getrennt. Siehe ``OpenCL
Optionen'' im ffmpeg-utils-Handbuch für die Liste der unterstützten Optionen.
AVOptionen
Diese Optionen werden direkt von libavformat, libavdevice und libavcodec bereitgestellt
Bibliotheken. Um die Liste der verfügbaren AVOptionen anzuzeigen, verwenden Sie die -Hilfe Möglichkeit. Sie sind
in zwei Kategorien unterteilt:
Generika
Diese Optionen können für jeden Container, Codec oder Gerät eingestellt werden. Generische Optionen sind
aufgeführt unter AVFormatContext-Optionen für Container/Geräte und unter AVCodecContext
Optionen für Codecs.
privat
Diese Optionen sind spezifisch für den angegebenen Container, das Gerät oder den Codec. Private Optionen
sind unter den entsprechenden Containern/Geräten/Codecs aufgeführt.
Um beispielsweise einen ID3v2.3-Header anstelle eines Standard-ID3v2.4 in eine MP3-Datei zu schreiben, verwenden Sie
id3v2_version private Option des MP3-Muxers:
ffmpeg -i input.flac -id3v2_version 3 out.mp3
Alle Codec-AVOptionen gelten pro Stream, und daher sollte ein Stream-Spezifizierer angehängt werden
Them.
Beachten Sie das -keine Option Syntax kann nicht für boolesche AVOptions verwendet werden, verwenden Sie -Möglichkeit 0/-Möglichkeit 1.
Hinweis: die alte undokumentierte Methode, AVOptions pro Stream anzugeben, indem v/a/s an . vorangestellt wird
Der Optionsname ist nun veraltet und wird in Kürze entfernt.
Main Optionen
-f fmt (Input-Output)
Eingabe- oder Ausgabedateiformat erzwingen. Das Format wird normalerweise automatisch für die Eingabe erkannt
Dateien und erraten von der Dateierweiterung für Ausgabedateien, daher ist diese Option nicht
in den meisten Fällen benötigt.
-i Dateinamen (Varianten des Eingangssignals:)
Dateiname eingeben
-y (globale )
Ausgabedateien überschreiben, ohne zu fragen.
-n (globale )
Ausgabedateien nicht überschreiben und sofort beenden, wenn bereits eine angegebene Ausgabedatei vorhanden ist
besteht.
-C[:stream_specifier] Codec (Eingabe/Ausgabe, pro Stream)
-codec[:stream_specifier] Codec (Eingabe/Ausgabe, pro Stream)
Wählen Sie einen Encoder (bei Verwendung vor einer Ausgabedatei) oder einen Decoder (bei Verwendung vor einer Ausgabedatei)
Eingabedatei) für einen oder mehrere Streams. Codec ist der Name eines Decoders/Encoders oder a
Sonderwert "copy" (nur Ausgabe), um anzuzeigen, dass der Stream nicht erneut
codiert.
Zum Beispiel
ffmpeg -i INPUT -map 0 -c:v libx264 -c:a copy OUTPUT
codiert alle Videostreams mit libx264 und kopiert alle Audiostreams.
Für jeden Stream wird die letzte passende Option "c" angewendet, also
ffmpeg -i INPUT -map 0 -c kopieren -c:v:1 libx264 -c:a:137 libvorbis OUTPUT
kopiert alle Streams außer dem zweiten Video, das mit libx264 codiert wird.
und das 138. Audio, das mit libvorbis kodiert wird.
-t Dauer (Input-Output)
Bei Verwendung als Eingabeoption (vor "-i") begrenzen Sie die Dauer von Daten gelesen aus dem
Eingabedatei.
Bei Verwendung als Ausgabeoption (vor einem Ausgabedateinamen) beenden Sie das Schreiben der Ausgabe
nachdem seine Dauer erreicht ist Dauer.
Dauer muss eine Zeitdauerangabe sein, siehe Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell.
-to und -t schließen sich gegenseitig aus und -t hat Priorität.
Zu Position (Möglichkeiten für das Ausgangssignal:)
Beenden Sie das Schreiben der Ausgabe um Position. Position muss eine Zeitdauerangabe sein,
sehen Uhrzeit Dauer Abschnitt in ffmpeg-utils(1) manuell.
-to und -t schließen sich gegenseitig aus und -t hat Priorität.
-fs limit_size (Möglichkeiten für das Ausgangssignal:)
Legen Sie die Dateigrößenbeschränkung in Bytes fest.
-ss Position (Input-Output)
Sucht bei Verwendung als Eingabeoption (vor "-i") in dieser Eingabedatei nach Position. Hinweis
dass es in den meisten Formaten nicht möglich ist, genau zu suchen, also ffmpeg werde nach dem suchen
nächster Suchpunkt vorher Position. Beim Transkodieren und -accurate_seek aktiviert
(Standardeinstellung), dieses zusätzliche Segment zwischen dem Suchpunkt und Position wird entschlüsselt
und verworfen. Beim Streamen kopieren oder wenn -noaccurate_seek verwendet wird, wird es sein
konserviert.
Bei Verwendung als Ausgabeoption (vor einem Ausgabedateinamen) wird die Eingabe dekodiert, aber verworfen
bis die Zeitstempel erreichen Position.
Position muss eine Zeitdauerangabe sein, siehe Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell.
-seof Position (Input-Output)
Wie die Option "-ss", aber relativ zum "Ende der Datei". Das heißt, negative Werte sind
weiter oben in der Datei steht 0 bei EOF.
-sein Offset Offset (Varianten des Eingangssignals:)
Stellen Sie den Eingabezeit-Offset ein.
Offset muss eine Zeitdauerangabe sein, siehe Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell.
Der Offset wird zu den Zeitstempeln der Eingabedateien hinzugefügt. Angabe eines positiven Offsets
bedeutet, dass die entsprechenden Streams um die in angegebene Zeitdauer verzögert werden
Offset.
-Zeitstempel Datum (Möglichkeiten für das Ausgangssignal:)
Legen Sie den Aufnahmezeitstempel im Container fest.
Datum muss eine Datumsangabe sein, siehe Datum Abschnitt in ffmpeg-utils(1) manuell.
-metadata[:metadata_specifier] Haupt=Wert (Ausgabe, pro Metadaten)
Legen Sie ein Schlüssel/Wert-Paar für Metadaten fest.
Ein optionales Metadatenspezifizierer kann angegeben werden, um Metadaten für Streams oder Kapitel festzulegen.
Weitere Informationen finden Sie in der Dokumentation zu "-map_metadata".
Diese Option überschreibt Metadaten, die mit "-map_metadata" festgelegt wurden. Es ist auch möglich zu löschen
Metadaten, indem Sie einen leeren Wert verwenden.
Um beispielsweise den Titel in der Ausgabedatei festzulegen:
ffmpeg -i in.avi -metadata title="my title" out.flv
So stellen Sie die Sprache des ersten Audiostreams ein:
ffmpeg -i INPUT -metadata:s:a:0 language=eng AUSGABE
-Ziel tippe (Möglichkeiten für das Ausgangssignal:)
Geben Sie den Zieldateityp ("vcd", "svcd", "dvd", "dv", "dv50") an. tippe kann vorangestellt werden
mit "pal-", "ntsc-" oder "film-", um den entsprechenden Standard zu verwenden. Das ganze Format
Optionen (Bitrate, Codecs, Puffergrößen) werden dann automatisch eingestellt. Sie können einfach eingeben:
ffmpeg -i meinedatei.avi -target vcd /tmp/vcd.mpg
Sie können jedoch zusätzliche Optionen angeben, solange Sie wissen, dass dies nicht der Fall ist
Konflikt mit dem Standard, wie in:
ffmpeg -i myfile.avi -target vcd -bf 2 /tmp/vcd.mpg
-dframes Anzahl (Möglichkeiten für das Ausgangssignal:)
Legen Sie die Anzahl der auszugebenden Datenrahmen fest. Dies ist ein Alias für "-frames:d".
-Rahmen[:stream_specifier] Frameanzahl (Ausgabe pro Stream)
Hör auf, danach in den Stream zu schreiben Frameanzahl Frames.
-Q[:stream_specifier] q (Ausgabe pro Stream)
-qskala[:stream_specifier] q (Ausgabe pro Stream)
Verwenden Sie eine feste Qualitätsskala (VBR). Die Bedeutung von q/qskala ist Codec-abhängig. Wenn qskala
wird ohne a verwendet stream_specifier dann gilt es nur für den Videostream, das ist
um die Kompatibilität mit dem vorherigen Verhalten aufrechtzuerhalten und denselben Codec anzugeben
spezifischer Wert für 2 verschiedene Codecs, das ist Audio und Video im Allgemeinen nicht das, was ist
beabsichtigt, wenn kein stream_specifier verwendet wird.
-Filter[:stream_specifier] Filtergrafik (Ausgabe pro Stream)
Erstellen Sie den durch . angegebenen Filtergraph Filtergrafik und verwenden Sie es, um den Stream zu filtern.
Filtergrafik ist eine Beschreibung des Filtergraphen, der auf den Stream angewendet werden soll, und muss haben
ein einzelner Eingang und ein einzelner Ausgang des gleichen Typs des Streams. In der Filtergrafik
der Eingang ist dem Label "in" und der Ausgang dem Label "out" zugeordnet. Siehe die
ffmpeg-filters-Handbuch für weitere Informationen über die Filtergraph-Syntax.
Weitere Informationen im -filter_komplex zu erhalten wenn Sie Filtergraphen mit mehreren Eingaben erstellen möchten
und/oder Ausgänge.
-filter_script[:stream_specifier] Dateinamen (Ausgabe pro Stream)
Diese Option ist ähnlich wie -Filter, der einzige Unterschied besteht darin, dass sein Argument die
Name der Datei, aus der eine Filtergraph-Beschreibung gelesen werden soll.
-Vor[:stream_specifier] Voreinstellungsname (Ausgabe pro Stream)
Geben Sie die Voreinstellung für übereinstimmende Streams an.
-Statistiken (globale )
Kodierungsfortschritt/Statistiken drucken. Es ist standardmäßig aktiviert, um es explizit zu deaktivieren
müssen "-nostats" angeben.
-Fortschritt URL (globale )
Sende programmfreundliche Fortschrittsinformationen an URL.
Fortschrittsinformationen werden ungefähr jede Sekunde geschrieben und am Ende des
Codiervorgang. Es ist gemacht aus "Haupt=Wert" Linien. Haupt besteht nur aus alphanumerischen
Zeichen. Der letzte Schlüssel einer Folge von Fortschrittsinformationen ist immer "Fortschritt".
-stdin
Aktivieren Sie die Interaktion bei der Standardeingabe. Standardmäßig aktiviert, es sei denn, die Standardeingabe wird als verwendet
eine Eingabe. Um die Interaktion explizit zu deaktivieren, müssen Sie "-nostdin" angeben.
Das Deaktivieren der Interaktion bei der Standardeingabe ist beispielsweise nützlich, wenn ffmpeg im
Hintergrundprozessgruppe. Ungefähr das gleiche Ergebnis kann mit "ffmpeg ...
/dev/null", aber es erfordert eine Shell.
-debug_ts (globale )
Zeitstempelinformationen drucken. Es ist standardmäßig deaktiviert. Diese Option ist vor allem nützlich für
Test- und Debugging-Zwecke, und das Ausgabeformat kann sich von einer Version zu ändern
eine andere, daher sollte sie nicht von portablen Skripten verwendet werden.
Siehe auch die Option "-fdebug ts".
-anfügen Dateinamen (Möglichkeiten für das Ausgangssignal:)
Fügen Sie der Ausgabedatei einen Anhang hinzu. Dies wird von einigen Formaten wie Matroska . unterstützt
B. für Schriftarten, die beim Rendern von Untertiteln verwendet werden. Anhänge werden spezifisch implementiert
Stream-Typ, sodass diese Option der Datei einen neuen Stream hinzufügt. Dann ist es möglich
um die Stream-Optionen für diesen Stream auf die übliche Weise zu verwenden. Anhänge-Streams erstellt
mit dieser Option werden nach allen anderen Streams erstellt (dh diejenigen, die mit erstellt wurden)
"-map" oder automatische Zuordnungen).
Beachten Sie, dass Sie für Matroska auch das Mimetype-Metadaten-Tag setzen müssen:
ffmpeg -i INPUT -attach DejaVuSans.ttf -metadata:s:2 mimetype=application/x-truetype-font out.mkv
(unter der Annahme, dass der Anhangsstream in der Ausgabedatei an dritter Stelle steht).
-dump_attachment[:stream_specifier] Dateinamen (Eingabe pro Stream)
Extrahieren Sie den passenden Anhangsstream in eine Datei namens Dateinamen. Wenn Dateinamen is
leer, dann wird der Wert des Metadaten-Tags "filename" verwendet.
ZB um den ersten Anhang in eine Datei namens 'out.ttf' zu extrahieren:
ffmpeg -dump_attachment:t:0 out.ttf -i INPUT
So extrahieren Sie alle Anhänge von Dateien, die durch das Tag "filename" bestimmt werden:
ffmpeg -dump_attachment:t "" -i INPUT
Technischer Hinweis – Anhänge werden als Codec-Extradaten implementiert, daher kann diese Option
tatsächlich verwendet werden, um Extradaten aus jedem Stream zu extrahieren, nicht nur Anhänge.
-keine automatische Drehung
Deaktivieren Sie das automatische Drehen von Videos basierend auf Dateimetadaten.
Video Optionen
-vframes Anzahl (Möglichkeiten für das Ausgangssignal:)
Legen Sie die Anzahl der auszugebenden Videobilder fest. Dies ist ein Alias für "-frames:v".
-R[:stream_specifier] fps (Eingabe/Ausgabe, pro Stream)
Bildrate einstellen (Hz-Wert, Bruch oder Abkürzung).
Ignorieren Sie als Eingabeoption alle in der Datei gespeicherten Zeitstempel und generieren Sie stattdessen
Zeitstempel unter Annahme einer konstanten Bildrate fps. Dies ist nicht dasselbe wie die -Framerate
Option, die für einige Eingabeformate wie image2 oder v4l2 verwendet wird (früher war sie dasselbe in
ältere Versionen von FFmpeg). Im Zweifelsfall verwenden -Framerate statt der Eingabemöglichkeit -r.
Als Ausgabeoption duplizieren oder löschen Sie Eingabeframes, um einen konstanten Ausgabeframe zu erzielen
Rate fps.
-S[:stream_specifier] Größe (Eingabe/Ausgabe, pro Stream)
Rahmengröße einstellen.
Als Eingabemöglichkeit ist dies eine Abkürzung für die Video Größe private Option, anerkannt
von einigen Demuxern, bei denen die Framegröße entweder nicht in der Datei gespeichert ist oder
konfigurierbar -- zB Rohvideo oder Videograbber.
Als Ausgabeoption fügt dies den Videofilter "scale" in die Ende dauert ebenfalls 3 Jahre. Das erste Jahr ist das sog.
entsprechende Filtergrafik. Bitte verwenden Sie den Filter "Skala" direkt, um ihn am
Anfang oder an einem anderen Ort.
Das Format ist B x H (Standard - wie Quelle).
-Aspekt[:stream_specifier] Aussehen (Ausgabe pro Stream)
Stellen Sie das Seitenverhältnis der Videoanzeige ein, das durch . angegeben wird Aussehen.
Aussehen kann ein String mit Gleitkommazahlen oder ein String der Form . sein num:am, Wobei
num und am sind Zähler und Nenner des Seitenverhältnisses. Zum Beispiel "4:3",
"16:9", "1.3333" und "1.7777" sind gültige Argumentwerte.
Bei Verwendung zusammen mit -vcodec Kopieren, beeinflusst dies das unter gespeicherte Seitenverhältnis
Containerebene, aber nicht das in codierten Frames gespeicherte Seitenverhältnis, falls vorhanden.
-vn (Möglichkeiten für das Ausgangssignal:)
Videoaufzeichnung deaktivieren.
-vcodec Codec (Möglichkeiten für das Ausgangssignal:)
Stellen Sie den Video-Codec ein. Dies ist ein Alias für "-codec:v".
-passieren[:stream_specifier] n (Ausgabe pro Stream)
Wählen Sie die Passnummer (1 oder 2). Es wird verwendet, um eine Videocodierung mit zwei Durchgängen durchzuführen. Die
Statistiken des Videos werden im ersten Durchgang in einer Logdatei aufgezeichnet (siehe auch die
Option -passlogfile), und im zweiten Durchgang wird diese Protokolldatei verwendet, um die
Video mit der genau angeforderten Bitrate. Bei Pass 1 können Sie einfach Audio deaktivieren und
setze output auf null, Beispiele für Windows und Unix:
ffmpeg -i foo.mov -c:v libxvid -pass 1 -an -f rawvideo -y NUL
ffmpeg -i foo.mov -c:v libxvid -pass 1 -an -f rawvideo -y /dev/null
-passlogfile[:stream_specifier] Präfix (Ausgabe pro Stream)
Setzen Sie das Namenspräfix für zwei Durchgänge auf Präfix, das standardmäßige Dateinamenpräfix ist
``ffmpeg2pass''. Der vollständige Dateiname lautet PRÄFIX-N.log, wobei N eine Zahl ist
spezifisch für den Ausgabestrom
-vf Filtergrafik (Möglichkeiten für das Ausgangssignal:)
Erstellen Sie den durch . angegebenen Filtergraph Filtergrafik und verwenden Sie es, um den Stream zu filtern.
Dies ist ein Alias für "-filter:v", siehe die -Filter zu erhalten.
Fortgeschrittener Video Optionen
-pix_fmt[:stream_specifier] Format (Eingabe/Ausgabe, pro Stream)
Pixelformat einstellen. Verwenden Sie "-pix_fmts", um alle unterstützten Pixelformate anzuzeigen. Wenn die
das ausgewählte Pixelformat kann nicht ausgewählt werden, ffmpeg druckt eine Warnung und wählt das
bestes Pixelformat, das vom Encoder unterstützt wird. Wenn pix_fmt wird ein "+" vorangestellt, ffmpeg
wird mit einem Fehler beendet, wenn das angeforderte Pixelformat nicht ausgewählt werden kann, und
automatische Konvertierungen innerhalb von Filtergraphen sind deaktiviert. Wenn pix_fmt ist ein einzelnes "+",
ffmpeg wählt das gleiche Pixelformat wie die Eingabe (oder Grafikausgabe) und automatisch
Konvertierungen sind deaktiviert.
-sws_flags Fahnen (Input-Output)
Setzt SwScaler-Flags.
-vdt n
Schwellenwert verwerfen.
-rc_override[:stream_specifier] Override (Ausgabe pro Stream)
Überschreiben der Ratensteuerung für bestimmte Intervalle, formatiert als "int,int,int"-Liste
durch Schrägstriche getrennt. Zwei erste Werte sind die Anfangs- und Endbildnummern, letzter
einer ist der zu verwendende Quantisierer, wenn er positiv ist, oder der Qualitätsfaktor, wenn er negativ ist.
-ilme
Interlacing-Unterstützung im Encoder erzwingen (nur MPEG-2 und MPEG-4). Verwenden Sie diese Option, wenn
Ihre Eingabedatei ist interlaced und Sie möchten das Interlaced-Format für ein Minimum beibehalten
Verluste. Die Alternative besteht darin, den Eingabestrom mit zu deinterlacen -deinterlacen, Aber
Deinterlacing führt zu Verlusten.
-psnr
Berechnen Sie PSNR komprimierter Frames.
-vstats
Videocodierungsstatistiken ausgeben in vstats_HHMMSS.log.
-vstats_file Datei
Videocodierungsstatistiken ausgeben in Datei.
-oben[:stream_specifier] n (Ausgabe pro Stream)
oben=1/unten=0/auto=-1 Feld zuerst
-dc Präzision
Intra_dc_precision.
-vtag vierccm/tag (Möglichkeiten für das Ausgangssignal:)
Video-Tag/Fourcc erzwingen. Dies ist ein Alias für "-tag:v".
-qphist (globale )
QP-Histogramm anzeigen
-vbsf bitstream_filter
Veraltet siehe -bsf
-force_key_frames[:stream_specifier] Zeit[,Zeit...] (Ausgabe pro Stream)
-force_key_frames[:stream_specifier] Ausdruck:ausdr (Ausgabe pro Stream)
Erzwinge Keyframes zu den angegebenen Zeitstempeln, genauer gesagt bei den ersten Frames danach
zu jeder angegebenen Zeit.
Wenn dem Argument "expr:" vorangestellt ist, wird die Zeichenfolge ausdr wird interpretiert wie ein
Ausdruck und wird für jeden Frame ausgewertet. Ein Keyframe wird erzwungen, falls die
Bewertung ist nicht Null.
Wenn eine der Zeiten ""Kapitel" ist[Delta]", es wird in die Zeit der erweitert
Anfang aller Kapitel in der Datei, verschoben um Delta, ausgedrückt als Zeit in
Sekunden. Diese Option kann nützlich sein, um sicherzustellen, dass bei a . ein Suchpunkt vorhanden ist
Kapitelmarkierung oder an einer anderen bestimmten Stelle in der Ausgabedatei.
Um beispielsweise einen Keyframe nach 5 Minuten einzufügen, plus Keyframes 0.1 Sekunden vor dem
Anfang jedes Kapitels:
-force_key_frames 0:05:00,Kapitel-0.1
Der Ausdruck in ausdr kann folgende Konstanten enthalten:
n die Nummer des aktuell verarbeiteten Frames, beginnend bei 0
n_erzwungen
die Anzahl der erzwungenen Frames
prev_forced_n
die Nummer des vorherigen erzwungenen Frames, es ist "NAN", wenn kein Keyframe erzwungen wurde
noch
prev_forced_t
die Zeit des vorherigen erzwungenen Frames, es ist "NAN", wenn noch kein Keyframe erzwungen wurde
t die Zeit des aktuell verarbeiteten Frames
Um beispielsweise alle 5 Sekunden einen Keyframe zu erzwingen, können Sie Folgendes angeben:
-force_key_frames Ausdruck:gte(t,n_forced*5)
Erzwingen eines Keyframes 5 Sekunden nach dem Zeitpunkt des letzten erzwungenen, beginnend mit
zweite 13:
-force_key_frames Ausdruck:if(isnan(prev_forced_t),gte(t,13),gte(t,prev_forced_t+5))
Beachten Sie, dass das Erzwingen zu vieler Keyframes für die Lookahead-Algorithmen von . sehr schädlich ist
bestimmte Encoder: Die Verwendung von Fixed-GOP-Optionen oder ähnlichem wäre effizienter.
-copyinkf[:stream_specifier] (Ausgabe pro Stream)
Kopieren Sie beim Stream-Kopie auch Nicht-Key-Frames, die am Anfang gefunden wurden.
-hwaccel[:stream_specifier] hwaccel (Eingabe pro Stream)
Verwenden Sie die Hardwarebeschleunigung, um den/die übereinstimmenden Stream(s) zu decodieren. Die zulässigen Werte von
hwaccel sind:
keine
Verwenden Sie keine Hardwarebeschleunigung (Standard).
Auto
Wählen Sie automatisch die Hardwarebeschleunigungsmethode aus.
vda Verwenden Sie die Apple VDA-Hardwarebeschleunigung.
vdau
Verwenden Sie die Hardwarebeschleunigung VDPAU (Video Decode and Presentation API for Unix).
dxva2
Verwenden Sie die Hardwarebeschleunigung DXVA2 (DirectX Video Acceleration).
Diese Option hat keine Auswirkung, wenn das ausgewählte hwaccel nicht verfügbar ist oder nicht unterstützt wird von
den gewählten Decoder.
Beachten Sie, dass die meisten Beschleunigungsmethoden für die Wiedergabe gedacht sind und nicht schneller sind
als Software-Dekodierung auf modernen CPUs. Zusätzlich, ffmpeg muss normalerweise kopieren
die dekodierten Frames aus dem GPU-Speicher in den Systemspeicher, was zu weiteren
Leistungsverlust. Diese Option ist daher hauptsächlich zum Testen nützlich.
-hwaccel_device[:stream_specifier] hwaccel_device (Eingabe pro Stream)
Wählen Sie ein Gerät aus, das für die Hardwarebeschleunigung verwendet werden soll.
Diese Option ist nur sinnvoll, wenn die -hwaccel Option ist ebenfalls angegeben. Es ist genau
Bedeutung hängt von der gewählten Hardwarebeschleunigungsmethode ab.
vdau
Für VDPAU gibt diese Option die zu verwendende X11-Anzeige/-Bildschirm an. Wenn diese Option ist
nicht angegeben, der Wert der DISPLAY Umgebungsvariable wird verwendet
dxva2
Für DXVA2 sollte diese Option die Nummer des zu verwendenden Anzeigeadapters enthalten.
Wenn diese Option nicht angegeben ist, wird der Standardadapter verwendet.
-hwaccels
Listen Sie alle in diesem Build von ffmpeg unterstützten Hardwarebeschleunigungsmethoden auf.
Audio Optionen
-Rahmen Anzahl (Möglichkeiten für das Ausgangssignal:)
Legen Sie die Anzahl der auszugebenden Audioframes fest. Dies ist ein Alias für "-frames:a".
-ar[:stream_specifier] Frequenz (Eingabe/Ausgabe, pro Stream)
Stellen Sie die Audio-Abtastfrequenz ein. Für Ausgabestreams ist es standardmäßig auf den
Frequenz des entsprechenden Eingangsstroms. Für Eingabestreams macht diese Option nur
Sinn für Audio-Grabbing-Geräte und Raw-Demuxer und wird den entsprechenden
Demuxer-Optionen.
-aq q (Möglichkeiten für das Ausgangssignal:)
Stellen Sie die Audioqualität ein (Codec-spezifisch, VBR). Dies ist ein Alias für -q:a.
-ac[:stream_specifier] Kanäle (Eingabe/Ausgabe, pro Stream)
Stellen Sie die Anzahl der Audiokanäle ein. Für Ausgabestreams ist es standardmäßig auf den
Anzahl der Eingangsaudiokanäle. Für Eingabestreams ist diese Option nur sinnvoll für
Audio-Grabbing-Geräte und Raw-Demuxer und wird dem entsprechenden Demuxer zugeordnet
Optionen.
-an (Möglichkeiten für das Ausgangssignal:)
Deaktivieren Sie die Audioaufnahme.
-codec Codec (Input-Output)
Stellen Sie den Audio-Codec ein. Dies ist ein Alias für "-codec:a".
-sample_fmt[:stream_specifier] sample_fmt (Ausgabe pro Stream)
Legen Sie das Audio-Sample-Format fest. Verwenden Sie "-sample_fmts", um eine Liste der unterstützten Beispiele zu erhalten
Formate.
-N Filtergrafik (Möglichkeiten für das Ausgangssignal:)
Erstellen Sie den durch . angegebenen Filtergraph Filtergrafik und verwenden Sie es, um den Stream zu filtern.
Dies ist ein Alias für "-filter:a", siehe die -Filter zu erhalten.
Fortgeschrittener Audio Optionen
-eine Markierung vierccm/tag (Möglichkeiten für das Ausgangssignal:)
Audio-Tag/Fourcc erzwingen. Dies ist ein Alias für "-tag:a".
-absf bitstream_filter
Veraltet, siehe -bsf
-guess_layout_max Kanäle (Eingabe pro Stream)
Wenn ein Eingangskanal-Layout nicht bekannt ist, versuchen Sie nur zu erraten, ob es at . entspricht
meisten die angegebene Anzahl von Kanälen. Zum Beispiel sagt 2 zu ffmpeg erkennen 1
Kanal als Mono und 2 Kanäle als Stereo, aber nicht 6 Kanäle als 5.1. Die Standardeinstellung ist zu
versuche immer zu erraten. Verwenden Sie 0, um alle Vermutungen zu deaktivieren.
Untertitel Optionen
-scodec Codec (Input-Output)
Stellen Sie den Untertitel-Codec ein. Dies ist ein Alias für "-codec:s".
-schn (Möglichkeiten für das Ausgangssignal:)
Untertitelaufnahme deaktivieren.
-sbsf bitstream_filter
Veraltet, siehe -bsf
Fortgeschrittener Untertitel Optionen
-fix_sub_duration
Untertiteldauer korrigieren. Warte für jeden Untertitel auf das nächste Paket im selben
Stream und passen Sie die Dauer des ersten an, um Überschneidungen zu vermeiden. Dies ist notwendig mit
einige Untertitel-Codecs, insbesondere DVB-Untertitel, weil die Dauer im Original
Paket ist nur eine grobe Schätzung und das Ende wird tatsächlich durch einen leeren Untertitel markiert
Rahmen. Wenn Sie diese Option bei Bedarf nicht verwenden, kann dies zu einer überhöhten Dauer führen
oder Muxing-Fehler aufgrund nicht monotoner Zeitstempel.
Beachten Sie, dass diese Option die Ausgabe aller Daten bis zum nächsten Untertitelpaket verzögert
dekodiert: Es kann den Speicherverbrauch und die Latenz stark erhöhen.
-Leinwandgröße Größe
Legen Sie die Größe der Leinwand fest, die zum Rendern von Untertiteln verwendet wird.
Fortgeschrittener Optionen
-Karte [-]input_file_id[:stream_specifier][,sync_file_id[:stream_specifier]] | [Linklabel]
(Möglichkeiten für das Ausgangssignal:)
Legen Sie einen oder mehrere Eingabestreams als Quelle für die Ausgabedatei fest. Jeder Eingabestrom
wird durch den Index der Eingabedatei identifiziert input_file_id und der Input-Stream-Index
input_stream_id innerhalb der Eingabedatei. Beide Indizes beginnen bei 0. Falls angegeben,
sync_file_id:stream_specifier legt fest, welcher Eingabestream als Präsentationssynchronisierung verwendet wird
Referenz.
Die erste Option "-map" in der Befehlszeile gibt die Quelle für Ausgabestream 0 an,
die zweite Option "-map" gibt die Quelle für Ausgabestrom 1 usw. an.
Ein "-"-Zeichen vor der Stream-ID erzeugt eine "negative" Zuordnung. Es
deaktiviert übereinstimmende Streams von bereits erstellten Mappings.
Eine Alternative [Linklabel] form wird Ausgaben von komplexen Filtergraphen zuordnen (siehe die
-filter_komplex Option) in die Ausgabedatei. Linklabel muss einem definierten . entsprechen
Ausgabe-Link-Label im Diagramm.
Um beispielsweise ALLE Streams aus der ersten Eingabedatei auf die Ausgabe zuzuordnen
ffmpeg -i INPUT -map 0 Ausgabe
Wenn Sie beispielsweise zwei Audiostreams in der ersten Eingabedatei haben, sind diese Streams
gekennzeichnet durch "0:0" und "0:1". Sie können "-map" verwenden, um auszuwählen, in welche Streams Sie platzieren möchten
eine Ausgabedatei. Zum Beispiel:
ffmpeg -i INPUT -map 0:1 aus.wav
wird den Eingabestrom in zuordnen SPEISUNG gekennzeichnet durch "0:1" zum (einzelnen) Ausgabestrom
in aus.wav.
Um beispielsweise den Stream mit Index 2 aus der Eingabedatei auszuwählen ein.mov (angegeben von der
Bezeichner "0:2") und Stream mit Index 6 von input b.mov (angegeben von der
Bezeichner "1:6") und in die Ausgabedatei kopieren aus.mov:
ffmpeg -i a.mov -i b.mov -c kopieren -map 0:2 -map 1:6 out.mov
So wählen Sie alle Videos und den dritten Audiostream aus einer Eingabedatei aus:
ffmpeg -i EINGANG -map 0:v -map 0:a:2 AUSGANG
Um alle Streams außer dem zweiten Audio zuzuordnen, verwenden Sie negative Zuordnungen
ffmpeg -i EINGANG -map 0 -map -0:a:1 AUSGANG
So wählen Sie den englischen Audiostream aus:
ffmpeg -i INPUT -map 0:m:Sprache:eng AUSGABE
Beachten Sie, dass die Verwendung dieser Option die Standardzuordnungen für diese Ausgabedatei deaktiviert.
-ignorieren_unbekannt
Ignorieren Sie Eingabestreams mit unbekanntem Typ, anstatt fehlzuschlagen, wenn das Kopieren solcher Streams
versucht.
-Kopie_unbekannt
Zulassen, dass Eingabestreams mit unbekanntem Typ kopiert werden, anstatt beim Kopieren fehlzuschlagen
Streams wird versucht.
-map_channel
[input_file_id.stream_specifier.Kanal ID|-1][:Ausgabe_Datei_ID.stream_specifier]
Ordnen Sie einen Audiokanal von einem bestimmten Eingang zu einem Ausgang zu. Wenn
Ausgabe_Datei_ID.stream_specifier nicht eingestellt ist, wird der Audiokanal auf allen abgebildet
die Audiostreams.
"-1" statt verwenden input_file_id.stream_specifier.Kanal ID wird eine stummgeschaltete Karte zuordnen
Kanal.
Angenommen zum Beispiel SPEISUNG eine Stereo-Audiodatei ist, können Sie die beiden Audio-
Kanäle mit folgendem Befehl:
ffmpeg -i INPUT -map_channel 0.0.1 -map_channel 0.0.0 AUSGABE
Wenn Sie den ersten Kanal stummschalten und den zweiten behalten möchten:
ffmpeg -i INPUT -map_channel -1 -map_channel 0.0.1 AUSGABE
Die Reihenfolge der Option "-map_channel" gibt die Reihenfolge der Kanäle im
Ausgabestrom. Das Ausgangskanallayout wird aus der Anzahl der zugeordneten Kanäle erraten
(Mono bei einem "-map_channel", Stereo bei zwei usw.). Verwendung von "-ac" in Kombination von
"-map_channel" bewirkt, dass die Kanalverstärkungspegel aktualisiert werden, wenn Eingangs- und Ausgangskanal
Layouts stimmen nicht überein (zum Beispiel zwei "-map_channel"-Optionen und "-ac 6").
Sie können auch jeden Kanal eines Eingangs zu bestimmten Ausgängen extrahieren; folgende
Befehl extrahiert zwei Kanäle des SPEISUNG Audiostream (Datei 0, Stream 0) zum
diejenigen AUSGANG_CH0 und AUSGANG_CH1 Ausgänge:
ffmpeg -i INPUT -map_channel 0.0.0 OUTPUT_CH0 -map_channel 0.0.1 OUTPUT_CH1
Das folgende Beispiel teilt die Kanäle eines Stereoeingangs in zwei separate Streams auf.
die in dieselbe Ausgabedatei geschrieben werden:
ffmpeg -i stereo.wav -map 0:0 -map 0:0 -map_channel 0.0.0:0.0 -map_channel 0.0.1:0.1 -y out.ogg
Beachten Sie, dass derzeit jeder Ausgabestream nur Kanäle von einem einzigen Eingang enthalten kann
Strom; Sie können beispielsweise nicht "-map_channel" verwenden, um mehrere Eingangsaudiokanäle auszuwählen
in verschiedenen Streams enthalten (aus denselben oder unterschiedlichen Dateien) und zusammenführen in
ein einzelner Ausgabestrom. Es ist daher z. B. derzeit nicht möglich, zu wenden
zwei separate Mono-Streams zu einem einzigen Stereo-Stream. Jedoch eine Stereoanlage aufteilen
Stream in zwei Einkanal-Monostreams ist möglich.
Wenn Sie diese Funktion benötigen, ist eine mögliche Problemumgehung die Verwendung der eine Zusammenführung Filter. Zum
Wenn Sie beispielsweise ein Medium zusammenführen müssen (hier input.mkv) mit 2 Mono-Audiostreams in
einen einzelnen Stereokanal-Audiostream (und den Videostream behalten), können Sie die
folgender Befehl:
ffmpeg -i input.mkv -filter_complex "[0:1] [0:2] amerge" -c:a pcm_s16le -c:v copy output.mkv
-map_metadata[:Metadaten_spec_out] im Ordner[:Metadaten_spec_in] (Ausgabe, pro Metadaten)
Metadateninformationen der nächsten Ausgabedatei festlegen von im Ordner. Beachten Sie, dass dies Dateien sind
Indizes (nullbasiert), keine Dateinamen. Optional Metadaten_spec_in/out Parameter
angeben, welche Metadaten kopiert werden sollen. Ein Metadatenspezifizierer kann die folgenden Formen haben:
g globale Metadaten, dh Metadaten, die für die gesamte Datei gelten
s[:stream_spez]
pro Stream-Metadaten. stream_spez ist ein Stream-Bezeichner, wie in der Beschreibung beschrieben Strom
Bezeichner Kapitel. In einem Eingabe-Metadaten-Bezeichner ist der erste übereinstimmende Stream
kopiert von. In einem Ausgabemetadatenbezeichner werden alle übereinstimmenden Streams kopiert.
c:Kapitel_index
Metadaten pro Kapitel. Kapitel_index ist der nullbasierte Kapitelindex.
p:Programmindex
Metadaten pro Programm. Programmindex ist der nullbasierte Programmindex.
Wenn der Metadatenbezeichner weggelassen wird, wird standardmäßig global verwendet.
Standardmäßig werden globale Metadaten aus der ersten Eingabedatei kopiert, pro Stream und pro
Kapitelmetadaten werden zusammen mit Streams/Kapiteln kopiert. Diese Standardzuordnungen sind
deaktiviert, indem Sie ein beliebiges Mapping des entsprechenden Typs erstellen. Ein negativer Dateiindex kann
Wird verwendet, um eine Dummy-Zuordnung zu erstellen, die nur das automatische Kopieren deaktiviert.
Zum Beispiel, um Metadaten aus dem ersten Stream der Eingabedatei nach global zu kopieren
Metadaten der Ausgabedatei:
ffmpeg -i in.ogg -map_metadata 0:s:0 aus.mp3
Um das Gegenteil zu tun, dh globale Metadaten in alle Audiostreams zu kopieren:
ffmpeg -i in.mkv -map_metadata:s:a 0:g aus.mkv
Beachten Sie, dass einfache 0 in diesem Beispiel auch funktionieren würde, da globale Metadaten
standardmäßig angenommen.
-map_chapters input_file_index (Möglichkeiten für das Ausgangssignal:)
Kopieren Sie Kapitel aus der Eingabedatei mit Index input_file_index zur nächsten Ausgabedatei. Wenn
keine Kapitelzuordnung angegeben ist, werden Kapitel aus der ersten Eingabedatei kopiert
mit mindestens einem Kapitel. Verwenden Sie einen negativen Dateiindex, um das Kopieren von Kapiteln zu deaktivieren.
-Benchmark (globale )
Benchmarking-Informationen am Ende einer Codierung anzeigen. Zeigt die verbrauchte CPU-Zeit und
maximaler Speicherverbrauch. Der maximale Speicherverbrauch wird nicht auf allen unterstützt
Systemen wird es normalerweise als 0 angezeigt, wenn es nicht unterstützt wird.
-benchmark_all (globale )
Benchmarking-Informationen während der Codierung anzeigen. Zeigt die in verschiedenen Schritten verbrauchte CPU-Zeit an
(Audio/Video-Kodierung/Dekodierung).
-Zeitlimit Dauer (globale )
Beenden Sie, nachdem ffmpeg für gelaufen ist Dauer Sekunden.
-Dump (globale )
Dump jedes Eingabepaket nach stderr.
-verhexen (globale )
Beim Dumpen von Paketen sollten Sie auch die Nutzlast ausgeben.
-Re (Varianten des Eingangssignals:)
Eingabe mit nativer Bildrate lesen. Wird hauptsächlich verwendet, um ein Greifgerät zu simulieren. oder Live-Input
streamen (zB beim Lesen aus einer Datei). Sollte nicht mit tatsächlichen Greifgeräten verwendet werden oder
Live-Eingangsstreams (wo es zu Paketverlusten kommen kann). Standardmäßig ffmpeg versucht zu
Lesen Sie die Eingabe(n) so schnell wie möglich. Diese Option verlangsamt das Lesen der
Eingang(en) auf die native Bildrate des/der Eingang(s). Es ist nützlich für die Echtzeitausgabe
(zB Live-Streaming).
-loop_input
Schleife über den Eingabestream. Derzeit funktioniert es nur für Bildstreams. Diese Option ist
für automatische FFserver-Tests verwendet. Diese Option ist veraltet, verwenden Sie -loop 1.
-loop_output Anzahl
Wiederholen Sie die Ausgabe für Formate, die Schleifen unterstützen, wie z. B. animiertes GIF (0 wird
Endlosschleifen der Ausgabe). Diese Option ist veraltet, verwenden Sie -loop.
-vsync Parameter
Videosynchronisierungsmethode. Aus Kompatibilitätsgründen können alte Werte als Zahlen angegeben werden.
Neu hinzugefügte Werte müssen immer als Strings angegeben werden.
0, Durchgang
Jeder Frame wird mit seinem Zeitstempel vom Demuxer an den Muxer übergeben.
1, vgl
Frames werden dupliziert und verworfen, um genau die gewünschte Konstante zu erreichen
Bildrate.
2, sehen
Frames werden mit ihrem Zeitstempel durchgereicht oder verworfen, um 2
Frames mit dem gleichen Zeitstempel.
fallen lassen
Als Passthrough, aber zerstört alle Zeitstempel, wodurch der Muxer frisch generiert wird
Zeitstempel basierend auf der Framerate.
-1, Auto
Wählt zwischen 1 und 2 je nach Muxer-Fähigkeiten. Dies ist die Standardeinstellung
Methode.
Beachten Sie, dass die Zeitstempel danach vom Muxer weiter modifiziert werden können. Zum
Beispiel für den Fall, dass die Formatoption vermeiden_negative_ts aktiviert.
Mit -map können Sie auswählen, aus welchem Stream die Zeitstempel genommen werden sollen. Du kannst
Lassen Sie entweder Video oder Audio unverändert und synchronisieren Sie den/die verbleibenden Stream(s) mit dem
unverändert ein.
-frame_drop_threshold Parameter
Frame-Drop-Schwellenwert, der angibt, wie viel hinter Video-Frames liegen können, bevor sie
fallengelassen werden. In Bildrateneinheiten ist 1.0 also ein Bild. Der Standardwert ist -1.1. Einer
möglicher Anwendungsfall ist, Framedrops bei verrauschten Zeitstempeln zu vermeiden oder zu erhöhen
Frame-Drop-Präzision bei exakten Zeitstempeln.
-asynchron Samples_per_Sekunde
Audiosynchronisierungsmethode. „Dehnt/drückt“ den Audiostream, damit er den Zeitstempeln entspricht, die
Parameter sind die maximalen Samples pro Sekunde, um die das Audio geändert wird. -asynchron 1
ist ein Sonderfall, bei dem nur der Anfang des Audiostreams ohne Korrektur korrigiert wird
spätere Korrektur.
Beachten Sie, dass die Zeitstempel danach vom Muxer weiter modifiziert werden können. Zum
Beispiel für den Fall, dass die Formatoption vermeiden_negative_ts aktiviert.
Diese Option ist veraltet. Verwenden Sie stattdessen den Audiofilter "aresample".
-Kopien
Verarbeiten Sie keine Eingabezeitstempel, sondern behalten Sie ihre Werte bei, ohne zu versuchen, sie zu bereinigen
Sie. Entfernen Sie insbesondere nicht den anfänglichen Startzeitversatzwert.
Beachten Sie, dass je nach vsync Option oder bei spezifischer Muxer-Verarbeitung (z. B. bei
die Formatoption vermeiden_negative_ts aktiviert ist) können die Ausgabezeitstempel nicht übereinstimmen
mit den eingegebenen Zeitstempeln, auch wenn diese Option ausgewählt ist.
-start_at_zero
Bei Verwendung mit Kopien, verschieben Sie die Eingabezeitstempel, sodass sie bei Null beginnen.
Dies bedeutet, dass die Verwendung von z. B. "-ss 50" dazu führt, dass die Ausgabezeitstempel bei 50 Sekunden beginnen,
unabhängig davon, mit welchem Zeitstempel die Eingabedatei begann.
-copytb Modus
Geben Sie an, wie die Encoder-Zeitbasis beim Kopieren von Streams festgelegt wird. Modus ist eine ganze Zahl
numerischer Wert und kann einen der folgenden Werte annehmen:
1 Verwenden Sie die Demuxer-Zeitbasis.
Die Zeitbasis wird vom entsprechenden Eingang zum Ausgangs-Encoder kopiert
demuxer. Dies ist manchmal erforderlich, um nicht monoton ansteigend zu vermeiden
Zeitstempel beim Kopieren von Videostreams mit variabler Bildrate.
0 Verwenden Sie die Decoder-Zeitbasis.
Die Zeitbasis wird vom entsprechenden Eingang zum Ausgangs-Encoder kopiert
Decoder.
-1 Versuchen Sie, die Auswahl automatisch zu treffen, um eine vernünftige Ausgabe zu generieren.
Der Standardwert ist -1.
-kürzeste (Möglichkeiten für das Ausgangssignal:)
Beenden Sie die Codierung, wenn der kürzeste Eingabestream endet.
-dts_delta_threshold
Zeitstempel-Diskontinuitäts-Delta-Schwellenwert.
-Muxverzögerung Sekunden (Varianten des Eingangssignals:)
Legen Sie die maximale Demux-Decodierungsverzögerung fest.
-muxpreload Sekunden (Varianten des Eingangssignals:)
Legen Sie die anfängliche Demux-Decodierungsverzögerung fest.
-streamid Output-Stream-Index:new-value (Möglichkeiten für das Ausgangssignal:)
Weisen Sie einem Ausgabestream einen neuen Stream-ID-Wert zu. Diese Option sollte angegeben werden
vor dem Ausgabedateinamen, für den es gilt. Für die Situation, in der mehrere
Ausgabedateien vorhanden sind, kann einer streamid ein anderer Wert zugewiesen werden.
Um beispielsweise die PID von Stream 0 auf 33 und die PID von Stream 1 auf 36 für einen Ausgang zu setzen
MPEGts-Datei:
ffmpeg -i infile -streamid 0:33 -streamid 1:36 out.ts
-bsf[:stream_specifier] bitstream_filter (Ausgabe pro Stream)
Legen Sie Bitstream-Filter für übereinstimmende Streams fest. bitstream_filter ist durch Kommas getrennt
Liste der Bitstream-Filter. Verwenden Sie die Option "-bsfs", um die Liste der Bitstreams zu erhalten
Filter.
ffmpeg -i h264.mp4 -c:v kopieren -bsf:v h264_mp4toannexb -an out.h264
ffmpeg -i file.mov -an -vn -bsf:s mov2textsub -c:s kopieren -f rawvideo sub.txt
-Schild[:stream_specifier] Codec-Tag (Eingabe/Ausgabe, pro Stream)
Erzwinge ein Tag/Fourcc für übereinstimmende Streams.
-Zeitcode hh:mm:ssSeptemberff
Geben Sie den Timecode zum Schreiben an. September ist ':' für Non-Drop-Timecode und ';' (oder für
fallen zu lassen.
ffmpeg -i input.mpg -timecode 01:02:03.04 -r 30000/1001 -s ntsc output.mpg
-filter_komplex Filtergrafik (globale )
Definieren Sie einen komplexen Filtergraphen, dh einen mit beliebig vielen Ein- und/oder Ausgängen.
Für einfache Graphen – solche mit einem Eingang und einem Ausgang desselben Typs – siehe die
-Filter Optionen. Filtergrafik ist eine Beschreibung des Filtergraphen, wie im
``Filtergraph-Syntax'' im Handbuch zu ffmpeg-filters.
Eingabe-Link-Labels müssen sich auf Eingabe-Streams beziehen, indem die
"[file_index:stream_specifier]"-Syntax (dh die gleiche wie -Karte Verwendet). Wenn
stream_specifier stimmt mit mehreren Streams überein, wird der erste verwendet. Ein unbeschriftetes
input wird mit dem ersten ungenutzten Input-Stream des übereinstimmenden Typs verbunden.
Ausgabe-Link-Labels werden mit . bezeichnet -Karte. Nicht gekennzeichnete Ausgaben werden zum ersten hinzugefügt
Ausgabedatei.
Beachten Sie, dass es mit dieser Option möglich ist, nur Lavfi-Quellen ohne Normal zu verwenden
Eingabedateien.
Zum Beispiel, um ein Bild über ein Video zu legen
ffmpeg -i video.mkv -i image.png -filter_complex '[0:v][1:v]overlay[out]' -map
'[out]' out.mkv
Hier bezieht sich "[0:v]" auf den ersten Videostream in der ersten Eingabedatei, der verlinkt wird
an den ersten (Haupt-)Eingang des Overlay-Filters. Ebenso der erste Videostream in
der zweite Eingang ist mit dem zweiten (Overlay-)Eingang von Overlay verknüpft.
Angenommen, jede Eingabedatei enthält nur einen Videostream, können wir Eingabelabels weglassen.
das obige ist also äquivalent zu
ffmpeg -i video.mkv -i image.png -filter_complex 'overlay[out]' -map
'[out]' out.mkv
Außerdem können wir das Ausgabelabel und die einzelne Ausgabe des Filtergraphen weglassen
wird der Ausgabedatei automatisch hinzugefügt, sodass wir einfach schreiben können
ffmpeg -i video.mkv -i image.png -filter_complex 'overlay' out.mkv
So erzeugen Sie 5 Sekunden reines rotes Video mit der Quelle "Farbe" von lavfi:
ffmpeg -filter_complex 'color=c=red' -t 5 out.mkv
-lavfi Filtergrafik (globale )
Definieren Sie einen komplexen Filtergraphen, dh einen mit beliebig vielen Ein- und/oder Ausgängen.
Gleichwertig -filter_komplex.
-filter_complex_script Dateinamen (globale )
Diese Option ist ähnlich wie -filter_komplex, der einzige Unterschied besteht darin, dass das Argument
der Name der Datei, aus der eine komplexe Filtergraph-Beschreibung gelesen werden soll.
-accurate_seek (Varianten des Eingangssignals:)
Diese Option aktiviert oder deaktiviert die genaue Suche in Eingabedateien mit dem -ss .
Sie ist standardmäßig aktiviert, sodass die Suche beim Transkodieren genau ist. Verwenden
-noaccurate_seek um es zu deaktivieren, was zB beim Kopieren einiger Streams nützlich sein kann und
die anderen umcodieren.
-seek_timestamp (Varianten des Eingangssignals:)
Diese Option aktiviert oder deaktiviert die Suche nach Zeitstempel in Eingabedateien mit dem -ss
Möglichkeit. Es ist standardmäßig deaktiviert. Wenn aktiviert, wird das Argument zum -ss Option ist
wird als tatsächlicher Zeitstempel betrachtet und wird nicht durch die Startzeit der Datei versetzt. Dies
ist nur für Dateien von Bedeutung, die nicht bei Zeitstempel 0 beginnen, wie z. B. Transportströme.
-thread_queue_size Größe (Varianten des Eingangssignals:)
Diese Option legt die maximale Anzahl von Paketen in der Warteschlange beim Lesen aus der Datei fest oder
Gerät. Bei Livestreams mit niedriger Latenz / hoher Rate können Pakete verworfen werden, wenn sie
werden nicht rechtzeitig gelesen; eine Erhöhung dieses Wertes kann dies vermeiden.
-override_ffserver (globale )
Überschreibt die Eingabespezifikationen von ffserver. Mit dieser Option können Sie beliebige
Eingabestream zu ffserver und steuern Sie viele Aspekte der Codierung von ffmpeg. Ohne
diese Option ffmpeg wird übertragen an ffserver was wird verlangt von ffserver.
Die Option ist für Fälle gedacht, in denen Funktionen benötigt werden, die nicht angegeben werden können
ffserver aber kann sein ffmpeg.
-sdp_datei Datei (globale )
Drucken Sie sdp-Informationen für einen Ausgabestream an Datei. Dies ermöglicht das Dumping von sdp
Informationen, wenn mindestens eine Ausgabe kein RTP-Stream ist. (Erfordert mindestens einen von
die Ausgabeformate rtp sein).
-verwerfen (Varianten des Eingangssignals:)
Ermöglicht das Verwerfen bestimmter Streams oder Frames von Streams beim Demuxer. Nicht alle
Demuxer unterstützen dies.
keine
Kein Rahmen verwerfen.
Standard
Standard, der keine Frames verwirft.
noref
Verwerfen Sie alle Nicht-Referenz-Frames.
bidir
Alle bidirektionalen Frames verwerfen.
kein Schlüssel
Alle Frames außer Keyframes verwerfen.
alle Verwerfen Sie alle Frames.
-xFehler (globale )
Stoppen und beenden bei Fehler
Als besondere Ausnahme können Sie einen Bitmap-Untertitelstream als Eingabe verwenden: Es wird
in ein Video mit der gleichen Größe wie das größte Video in der Datei umgewandelt, oder 720 x 576, wenn
es ist kein Video vorhanden. Beachten Sie, dass dies eine experimentelle und vorübergehende Lösung ist. Es wird sein
entfernt, sobald libavfilter die richtige Unterstützung für Untertitel hat.
Um beispielsweise Untertitel auf einer im MPEG-TS-Format gespeicherten DVB-T-Aufnahme fest zu codieren,
Untertitel um 1 Sekunde verzögern:
ffmpeg -i input.ts -filter_complex \
'[#0x2ef] setpts=PTS+1/TB [sub] ; [#0x2d0] [sub] Overlay' \
-sn -map '#0x2dc' Ausgabe.mkv
(0x2d0, 0x2dc und 0x2ef sind die MPEG-TS PIDs von Video, Audio bzw
Untertitel-Streams; 0:0, 0:3 und 0:7 hätten auch funktioniert)
Preset Dateien
Eine Preset-Datei enthält eine Sequenz von zu erhalten=Wert Paare, eines für jede Zeile, mit Angabe von a
Reihenfolge von Optionen, deren Angabe in der Befehlszeile umständlich wäre. Linien beginnend
mit Raute ('#') werden ignoriert und für Kommentare verwendet. Überprüf den
Presets Verzeichnis im FFmpeg-Quellbaum für Beispiele.
Es gibt zwei Arten von Preset-Dateien: ffpreset- und avpreset-Dateien.
ffvoreinstellung Dateien
ffpreset-Dateien werden mit den Optionen "vpre", "apre", "spre" und "fpre" angegeben. Die
Die Option "fpre" nimmt den Dateinamen des Presets anstelle eines Presetnamens als Eingabe und kann
für jede Art von Codec verwendet werden. Für die Optionen "vpre", "apre" und "spre" sind die Optionen
die in einer voreingestellten Datei angegeben sind, werden auf den aktuell ausgewählten Codec des gleichen Typs angewendet wie
die voreingestellte Option.
Das an die Preset-Optionen "vpre", "apre" und "spre" übergebene Argument identifiziert das Preset
Datei nach folgenden Regeln zu verwenden:
Zuerst sucht ffmpeg nach einer Datei namens arg.ffpreset in den Verzeichnissen $FFMPEG_DATADIR (ob
eingestellt) und $HOME/.ffmpeg, und im Datenverzeichnis, das zur Konfigurationszeit definiert wurde (normalerweise
PRÄFIX/share/ffmpeg) oder in a ffVoreinstellungen Ordner entlang der ausführbaren Datei auf Win32, in dem
Auftrag. Wenn das Argument beispielsweise "libvpx-1080p" lautet, wird nach der Datei gesucht
libvpx-1080p.ffpreset.
Wenn keine solche Datei gefunden wird, sucht ffmpeg nach einer Datei namens Codec-Name-arg.ffvoreinstellung
in den oben genannten Verzeichnissen, wo Codec-Name ist der Name des Codecs, zu dem die
voreingestellte Dateioptionen werden angewendet. Wenn Sie beispielsweise den Videocodec mit . auswählen
"-vcodec libvpx" und verwenden Sie "-vpre 1080p", dann wird nach der Datei gesucht
libvpx-1080p.ffpreset.
Voreinstellung Dateien
avpreset-Dateien werden mit der Option "pre" angegeben. Sie funktionieren ähnlich wie ffpreset-Dateien,
Sie erlauben jedoch nur geberspezifische Optionen. Daher ein zu erhalten=Wert Paarangabe
ein Encoder kann nicht verwendet werden.
Wenn die Option "pre" angegeben ist, sucht ffmpeg nach Dateien mit der Endung .avpreset
in den Verzeichnissen $AVCONV_DATADIR (falls eingestellt) und $HOME/.avconv, und im Datenverzeichnis definiert
zur Konfigurationszeit (normalerweise PRÄFIX/share/ffmpeg), in dieser Reihenfolge.
Zuerst sucht ffmpeg nach einer Datei namens Codec-Name-arg.avpreset im oben genannten
Verzeichnisse, wo Codec-Name ist der Name des Codecs, für den die voreingestellten Dateioptionen
Wird angewendet werden. Wenn Sie beispielsweise den Videocodec mit "-vcodec libvpx" auswählen und verwenden
"-pre 1080p", dann wird nach der Datei gesucht libvpx-1080p.avpreset.
Wenn keine solche Datei gefunden wird, sucht ffmpeg nach einer Datei namens arg.avpreset im
gleiche Verzeichnisse.
Beispiele:
Video und Audio Grabbing
Wenn Sie das Eingabeformat und das Gerät angeben, kann ffmpeg Video und Audio direkt aufnehmen.
ffmpeg -f oss -i /dev/dsp -f video4linux2 -i /dev/video0 /tmp/out.mpg
Oder mit einer ALSA-Audioquelle (Mono-Eingang, Karten-ID 1) anstelle von OSS:
ffmpeg -f alsa -ac 1 -i hw:1 -f video4linux2 -i /dev/video0 /tmp/out.mpg
Beachten Sie, dass Sie die richtige Videoquelle und den richtigen Kanal aktivieren müssen, bevor Sie ffmpeg starten
mit jedem TV-Zuschauer wiehttp://linux.bytesex.org/xawtv/> von Gerd Knorr. Sie haben auch
um die Audioaufnahmepegel mit einem Standard-Mixer richtig einzustellen.
X11 Grabbing
Holen Sie sich das X11-Display mit ffmpeg über
ffmpeg -f x11grab -video_size cif -framerate 25 -i :0.0 /tmp/out.mpg
0.0 ist die display.screen-Nummer Ihres X11-Servers, genau wie die Umgebungsvariable DISPLAY.
ffmpeg -f x11grab -video_size cif -framerate 25 -i :0.0+10,20 /tmp/out.mpg
0.0 ist die display.screen-Nummer Ihres X11-Servers, genau wie die Umgebungsvariable DISPLAY.
10 ist der x-Offset und 20 der y-Offset für das Greifen.
Video und Audio Datei Format Umwandlung
Jedes unterstützte Dateiformat und Protokoll kann als Eingabe für ffmpeg dienen:
Beispiele:
· Sie können YUV-Dateien als Eingabe verwenden:
ffmpeg -i /tmp/test%dY /tmp/out.mpg
Es verwendet die Dateien:
/tmp/test0.Y, /tmp/test0.U, /tmp/test0.V,
/tmp/test1.Y, /tmp/test1.U, /tmp/test1.V usw...
Die Y-Dateien verwenden die doppelte Auflösung der U- und V-Dateien. Sie sind Rohdateien, ohne
Header. Sie können von allen anständigen Videodecodern erzeugt werden. Sie müssen die Größe angeben
des Bildes mit dem -s Option, wenn ffmpeg es nicht erraten kann.
· Sie können aus einer rohen YUV420P-Datei eingeben:
ffmpeg -i /tmp/test.yuv /tmp/out.avi
test.yuv ist eine Datei, die rohe YUV-Planardaten enthält. Jeder Frame besteht aus dem Y
Ebene gefolgt von der U- und V-Ebene mit halber vertikaler und horizontaler Auflösung.
· Sie können in eine rohe YUV420P-Datei ausgeben:
ffmpeg -i mydivx.avi riesigefile.yuv
· Sie können mehrere Eingabedateien und Ausgabedateien einstellen:
ffmpeg -i /tmp/a.wav -s 640x480 -i /tmp/a.yuv /tmp/a.mpg
Konvertiert die Audiodatei a.wav und die rohe YUV-Videodatei a.yuv in eine MPEG-Datei a.mpg.
· Sie können auch gleichzeitig Audio- und Videokonvertierungen durchführen:
ffmpeg -i /tmp/a.wav -ar 22050 /tmp/a.mp2
Konvertiert a.wav in MPEG-Audio mit einer Abtastrate von 22050 Hz.
· Sie können gleichzeitig in mehrere Formate codieren und ein Mapping von der Eingabe definieren
Stream zu Ausgabestreams:
ffmpeg -i /tmp/a.wav -map 0:a -b:a 64k /tmp/a.mp2 -map 0:a -b:a 128k /tmp/b.mp2
Konvertiert a.wav in a.mp2 mit 64 kbits und in b.mp2 mit 128 kbits. '-map-Datei:Index'
gibt an, welcher Eingabestrom für jeden Ausgabestrom verwendet wird, in der Reihenfolge der
Definition von Ausgabeströmen.
· Sie können entschlüsselte VOBs transkodieren:
ffmpeg -i snatch_1.vob -f avi -c:v mpeg4 -b:v 800k -g 300 -bf 2 -c:a libmp3lame -b:a 128k snatch.avi
Dies ist ein typisches Beispiel für das Rippen von DVDs; die Eingabe ist eine VOB-Datei, die Ausgabe eine AVI-Datei
mit MPEG-4-Video und MP3-Audio. Beachten Sie, dass wir in diesem Befehl B-Frames verwenden, damit die
MPEG-4-Stream ist DivX5-kompatibel und die GOP-Größe beträgt 300, was ein Intra-Frame bedeutet
alle 10 Sekunden für 29.97fps Eingangsvideo. Außerdem ist der Audiostream
MP3-codiert, daher müssen Sie die LAME-Unterstützung aktivieren, indem Sie "--enable-libmp3lame" an . übergeben
konfigurieren. Das Mapping ist besonders nützlich für die DVD-Transkodierung, um die gewünschte
Audiosprache.
HINWEIS: Um die unterstützten Eingabeformate anzuzeigen, verwenden Sie "ffmpeg -formats".
· Sie können Bilder aus einem Video extrahieren oder ein Video aus vielen Bildern erstellen:
So extrahieren Sie Bilder aus einem Video:
ffmpeg -i foo.avi -r 1 -s WxH -f image2 foo-%03d.jpeg
Dadurch wird ein Videobild pro Sekunde aus dem Video extrahiert und in ausgegeben
Dateien benannt foo-001.jpeg, foo-002.jpeg, usw. Bilder werden neu skaliert, um sie an das neue anzupassen
BxH-Werte.
Wenn Sie nur eine begrenzte Anzahl von Frames extrahieren möchten, können Sie den obigen Befehl verwenden
in Kombination mit der Option -vframes oder -t oder in Kombination mit -ss zum Starten
ab einem bestimmten Zeitpunkt herausziehen.
So erstellen Sie ein Video aus vielen Bildern:
ffmpeg -f image2 -framerate 12 -i foo-%03d.jpeg -s WxH foo.avi
Die Syntax "foo-%03d.jpeg" gibt an, eine aus drei Ziffern bestehende Dezimalzahl zu verwenden
mit Nullen aufgefüllt, um die Sequenznummer auszudrücken. Es ist die gleiche Syntax, die von unterstützt wird
die C printf-Funktion, aber nur Formate, die eine normale ganze Zahl akzeptieren, sind geeignet.
Beim Importieren einer Bildsequenz unterstützt -i auch das Erweitern von Shell-ähnlichen Platzhaltern
Muster (globbing) intern, durch Auswahl des image2-spezifischen "-pattern_type glob"
.
Zum Beispiel zum Erstellen eines Videos aus Dateinamen, die dem Glob-Muster entsprechen
"foo-*.jpeg":
ffmpeg -f image2 -pattern_type glob -framerate 12 -i 'foo-*.jpeg' -s WxH foo.avi
· Sie können viele Streams des gleichen Typs in die Ausgabe einfügen:
ffmpeg -i test1.avi -i test2.avi -map 1:1 -map 1:0 -map 0:1 -map 0:0 -c kopieren -y test12.nut
Die resultierende Ausgabedatei test12.nut enthält die ersten vier Streams aus dem
Eingabedateien in umgekehrter Reihenfolge.
· So erzwingen Sie die CBR-Videoausgabe:
ffmpeg -i myfile.avi -b 4000k -minrate 4000k -maxrate 4000k -bufsize 1835k aus.m2v
· Die vier Optionen lmin, lmax, mblmin und mblmax verwenden 'Lambda'-Einheiten, aber Sie können die
QP2LAMBDA-Konstante zur einfachen Umrechnung von 'q'-Einheiten:
ffmpeg -i src.ext -lmax 21*QP2LAMBDA dst.ext
SYNTAX
In diesem Abschnitt werden die Syntax und die Formate dokumentiert, die von den FFmpeg-Bibliotheken und -Tools verwendet werden.
Zitieren und Flucht
FFmpeg verwendet den folgenden Quotierungs- und Escape-Mechanismus, sofern nicht ausdrücklich angegeben.
Es gelten folgende Regeln:
· ' und \ sind Sonderzeichen (die jeweils für Anführungszeichen und Escape-Zeichen verwendet werden). In
Zusätzlich zu ihnen kann es je nach Spezifizierung weitere Sonderzeichen geben
Syntax, bei der Escape- und Anführungszeichen verwendet werden.
· Ein Sonderzeichen wird durch ein vorangestelltes a . maskiert \.
· Alle Zeichen eingeschlossen zwischen '' sind buchstäblich in der geparsten Zeichenfolge enthalten. Die
Zitat Charakter ' selbst kann nicht zitiert werden, daher müssen Sie möglicherweise das Zitat schließen und
entkommen ihm.
· Führende und nachgestellte Leerzeichen, sofern sie nicht mit Escapezeichen oder Anführungszeichen versehen sind, werden aus dem . entfernt
geparste Zeichenfolge.
Beachten Sie, dass Sie möglicherweise eine zweite Escape-Ebene hinzufügen müssen, wenn Sie die Befehlszeile oder a . verwenden
Skript, das von der Syntax der verwendeten Shell-Sprache abhängt.
Die Funktion "av_get_token" definiert in libavutil/avstring.h kann verwendet werden, um ein Token zu parsen
nach den oben definierten Regeln zitiert oder mit Escapezeichen versehen.
Das Tool, dass werkzeuge/ffescape im FFmpeg-Quellbaum kann verwendet werden, um automatisch zu zitieren oder
Escape für einen String in einem Skript.
Beispiele
· Escape die Zeichenfolge "Crime d'Amour", die das Sonderzeichen "'" enthält:
Crime d\'Amour
· Die obige Zeichenfolge enthält ein Anführungszeichen, daher muss das "'" bei Anführungszeichen mit Escapezeichen versehen werden:
'Crime d'\''Amour'
· Fügen Sie führende oder nachgestellte Leerzeichen in Anführungszeichen ein:
' dieser String beginnt und endet mit Leerzeichen '
· Escape und Quoting können miteinander vermischt werden:
' Der String '\'string\'' ist ein String '
· Um ein Literal einzuschließen \ Sie können entweder Escape- oder Anführungszeichen verwenden:
'c:\foo' kann als c:\\foo . geschrieben werden
Datum
Die akzeptierte Syntax ist:
[(JJJJ-MM-TT|JJJJMMTT)[T|t| ]]((HH:MM:SS[.m...]]])|(HHMMSS[.m...]]]))[Z]
jetzt an
Wenn der Wert "jetzt" ist, wird die aktuelle Zeit verwendet.
Die Zeit ist die Ortszeit, es sei denn, Z wird angehängt, in diesem Fall wird sie als UTC interpretiert. Wenn die
Jahr-Monat-Tag-Teil ist nicht angegeben, es wird das aktuelle Jahr-Monat-Tag verwendet.
Uhrzeit Dauer
Es gibt zwei akzeptierte Syntaxen zum Ausdrücken der Zeitdauer.
[-][ :] : [. ...]
HH drückt die Anzahl der Stunden aus, MM die Anzahl der Minuten für maximal 2 Stellen und
SS die Anzahl der Sekunden für maximal 2 Stellen. Die m am Ende drückt dezimal aus
Wert für SS.
or
[-] +[. ...]
S drückt die Anzahl der Sekunden aus, mit dem optionalen Dezimalteil m.
In beiden Ausdrücken ist das optionale - zeigt eine negative Dauer an.
Beispiele
Die folgenden Beispiele sind alle gültige Zeitdauern:
55 55 Sekunden
12:03:45
12 Stunde, 03 Minuten und 45 Sekunden
23.189
23.189 Sekunden
Video Größe
Geben Sie die Größe des Quellvideos an, es kann eine Zeichenfolge der Form sein BreitexHöheOder das
Name einer Größenabkürzung.
Folgende Abkürzungen sind bekannt:
ntsc
720x480
Kumpel 720x576
qntsc
352x240
qpal
352x288
sntsc
640x480
spal
768x576
Film
352x240
NTSC-Film
352x240
sqcif
128x96
qcif
176x144
cif 352x288
4cif
704x576
16cif
1408x1152
qqvga
160x120
qvga
320x240
vga 640x480
Svga
800x600
xga 1024x768
uxga
1600x1200
qxga
2048x1536
sxga
1280x1024
qsga
2560x2048
hsxga
5120x4096
wvga
852x480
wxga
1366x768
wsxga
1600x1024
Wuxga
1920x1200
woxga
2560x1600
wqsxga
3200x2048
wquxga
3840x2400
wsxga
6400x4096
whuxga
7680x4800
CGA 320x200
ega 640x350
hd480
852x480
hd720
1280x720
hd1080
1920x1080
2k 2048x1080
2kflach
1998x1080
2kBereich
2048x858
4k 4096x2160
4kflach
3996x2160
4kBereich
4096x1716
nhd 640x360
hqvga
240x160
wqvga
400x240
fwqvga
432x240
hvga
480x320
QHD 960x540
2kdci
2048x1080
4kdci
4096x2160
äh2160
3840x2160
äh4320
7680x4320
Video Rate
Geben Sie die Bildrate eines Videos an, ausgedrückt als Anzahl der pro Sekunde erzeugten Bilder.
Es muss ein String im Format sein Frame_Rate_num/Frame_Rate_Den, eine ganze Zahl, a
Gleitkommazahl oder eine gültige Abkürzung für die Videobildrate.
Folgende Abkürzungen sind bekannt:
ntsc
30000/1001
Kumpel 25/1
qntsc
30000/1001
qpal
25/1
sntsc
30000/1001
spal
25/1
Film
24/1
NTSC-Film
24000/1001
Ratio
Ein Verhältnis kann als Ausdruck oder in der Form Zähler:Nenner.
Beachten Sie, dass ein Verhältnis mit unendlich (1/0) oder negativem Wert als gültig angesehen wird, also sollten Sie
Überprüfen Sie den zurückgegebenen Wert, wenn Sie diese Werte ausschließen möchten.
Der undefinierte Wert kann mit der Zeichenfolge "0:0" ausgedrückt werden.
Farbe
Dies kann der Name einer Farbe sein, wie unten definiert (Groß-/Kleinschreibung wird nicht beachtet) oder a
"[0x|#]RRGGBB[AA]"-Sequenz, möglicherweise gefolgt von @ und einer Zeichenfolge, die das Alpha darstellt
Komponente.
Die Alpha-Komponente kann eine Zeichenfolge sein, die aus "0x" gefolgt von einer hexadezimalen Zahl besteht oder
eine Dezimalzahl zwischen 0.0 und 1.0, die den Deckkraftwert darstellt (0x00 or 0.0
bedeutet völlig transparent, 0xff or 1.0 völlig undurchsichtig). Wenn die Alpha-Komponente ist
dann nicht angegeben 0xff wird angenommen.
Die Zeichenfolge zufällig führt zu einer zufälligen Farbe.
Die folgenden Farbnamen werden erkannt:
Alice blau
0xF0F8FF
Altweiß
0xFAEBD7
Aqua
0x00FFFF
Aquamarin
0x7FFFD4
Azure
0xF0FFFF
Beige
0xF5F5DC
Fischcremesuppe
0xFFE4C4
Schwarz
0x000000
Blanchierte Mandel
0xFFEBCD
Blau
0x0000FF
Blau Violett
0x8A2BE2
Brown
0xA52A2A
burlywood
0xDEB887
Kadettenblau
0x5F9EA0
Kartause
0x7FFF00
Schokolade
0xD2691E
Coral
0xFF7F50
Kornblumenblau
0x6495ED
Cornsilk
0xFFF8DC
Crimson
0xDC143C
Cyan
0x00FFFF
Dunkelblau
0x00008B
DarkCyan
0x008B8B
DunkelGoldenRod
0xB8860B
Dunkelgrau
0xA9A9A9
Dunkelgrün
0x006400
DarkKhaki
0xBDB76B
DarkMagenta
0x8B008B
DarkOliveGreen
0x556B2F
Dunkelorange
0xFF8C00
DarkOrchid
0x9932CC
Dunkelrot
0x8B0000
DarkSalmon
0xE9967A
DarkSeaGreen
0x8FBC8F
DarkSlateBlue
0x483D8B
DarkSlateGray
0x2F4F4F
DarkTurquoise
0x00CED1
Dunkelviolett
0x9400D3
Dunkelrosa
0xFF1493
DeepSkyBlue
0x00BFFF
DimGray
0x696969
DodgerBlue
0x1E90FF
FireBrick
0xB22222
Blumenweiß
0xFFFAF0
Waldgrün
0x228B22
Fuchsia
0xFF00FF
Gainsboro
0xDCDCDC
GhostWhite
0xF8F8FF
Gold
0xFFD700
Goldrute
0xDAA520
Gray
0x808080
Grün
0x008000
Grün Gelb
0xADFF2F
Honigtau
0xF0FFF0
HotPink
0xFF69B4
IndianRed
0xCD5C5C
Indigoblau
0x4B0082
Elfenbein
0xFFFFF0
Khaki
0xF0E68C
Lavendel
0xE6E6FA
LavenderBlush
0xFFF0F5
Rasengrün
0x7CFC00
ZitronenChiffon
0xFFFACD
Hellblau
0xADD8E6
LightCoral
0xF08080
LightCyan
0xE0FFFF
LichtGoldenRodGelb
0xFAFAD2
Hellgrün
0x90EE90
Hellgrau
0xD3D3D3
Hell-Pink
0xFFB6C1
LightSalmon
0xFFA07A
LightSeaGreen
0x20B2AA
LightSkyBlue
0x87CEFA
LightSlateGray
0x778899
LightSteelBlue
0xB0C4DE
Hellgelb
0xFFFFE0
Gelb
0x00FF00
LimeGreen
0x32CD32
Leinen
0xFAF0E6
Magenta
0xFF00FF
Kastanienbraun
0x800000
MediumAquaMarine
0x66CDAA
Mittelblau
0x0000CD
MediumOrchid
0xBA55D3
MediumPurple
0x9370D8
MediumSeaGreen
0x3CB371
MediumSlateBlue
0x7B68EE
MittelFrühlingGrün
0x00FA9A
MittelTürkis
0x48D1CC
MediumVioletRed
0xC71585
Mitternachtsblau
0x191970
MintCream
0xF5FFFA
MistyRose
0xFFE4E1
Mokassin
0xFFE4B5
NavajoWeiß
0xFFDEAD
Marineblau
0x000080
OldLace
0xFDF5E6
Olive
0x808000
Olivedrab
0x6B8E23
Orange
0xFFA500
Orange Rot
0xFF4500
Orchidee
0xDA70D6
BlassGoldenRod
0xEEE8AA
palegreen
0x98FB98
BlassTürkis
0xAFEEEE
PaleVioletRed
0xD87093
PapayaPeitsche
0xFFEFD5
PeachPuff
0xFFDAB9
Peru
0xCD853F
Rosa
0xFFC0CB
Pflaume
0xDDA0DD
PowderBlue
0xB0E0E6
Lila
0x800080
Rot 0xFF0000
RosyBrown
0xBC8F8F
Königsblau
0x4169E1
Sattelbraun
0x8B4513
Lachs
0xFA8072
SandyBrown
0xF4A460
Meeresgrün
0x2E8B57
SeaShell
0xFFF5EE
Sienaerde
0xA0522D
Silber
0xC0C0C0
Himmelblau
0x87CEEB
SlateBlue
0x6A5ACD
Schiefer grau
0x708090
Snow
0xFFFAFA
Frühlingsgrün
0x00FF7F
SteelBlue
0x4682B4
Tan 0xD2B48C
Teal
0x008080
Distel
0xD8BFD8
Tomate
0xFF6347
Türkis
0x40E0D0
Lila
0xEE82EE
Weizen
0xF5DEB3
Weiß
0xFFFFFF
Weißer Rauch
0xF5F5F5
Gelb
0xFFFF00
Gelbgrün
0x9ACD32
Kanal Layout
Ein Kanallayout legt die räumliche Anordnung der Kanäle in einem Multikanal fest
Audiostream. Um ein Kanallayout anzugeben, verwendet FFmpeg eine spezielle Syntax.
Einzelne Kanäle werden durch eine ID identifiziert, wie in der folgenden Tabelle angegeben:
FL vorne links
FR vorne rechts
FC vorne mitte
LFE niederfrequenten
BL hinten links
BR hinten rechts
FLC vorne links von der Mitte
FRC vorne rechts von der Mitte
BC hinten mitte
SL Seite links
SR Seite rechts
TC oben in der Mitte
TFL oben vorne links
TFC oben vorne mitte
Abfindung oben vorne rechts
TBL oben hinten links
TBC oben hinten mitte
TBR oben hinten rechts
DL links runtermischen
DR richtig runtermischen
WL weit links
WR weit rechts
SDL Surround direkt links
SDR Surround direkt rechts
LFE2, XNUMX
niedrige Frequenz 2
Standard-Kanal-Layout-Kompositionen können mit den folgenden Bezeichnern angegeben werden:
Mono
FC
Stereo
FL+FR
2.1 FL+FR+LFE
3.0 FL+FR+FC
3.0 (zurück)
FL+FR+BC
4.0 FL+FR+FC+BC
Quad (Vierleiter)
FL+FR+BL+BR
Quad (Seite)
FL+FR+SL+SR
3.1 FL+FR+FC+LFE
5.0 FL+FR+FC+BL+BR
5.0(Seite)
FL+FR+FC+SL+SR
4.1 FL+FR+FC+LFE+BC
5.1 FL+FR+FC+LFE+BL+BR
5.1(Seite)
FL+FR+FC+LFE+SL+SR
6.0 FL+FR+FC+BC+SL+SR
6.0 (vorne)
FL+FR+FLC+FRC+SL+SR
hexagonal
FL+FR+FC+BL+BR+BC
6.1 FL+FR+FC+LFE+BC+SL+SR
6.1 FL+FR+FC+LFE+BL+BR+BC
6.1 (vorne)
FL+FR+LFE+FLC+FRC+SL+SR
7.0 FL+FR+FC+BL+BR+SL+SR
7.0 (vorne)
FL+FR+FC+FLC+FRC+SL+SR
7.1 FL+FR+FC+LFE+BL+BR+SL+SR
7.1 (breit)
FL+FR+FC+LFE+BL+BR+FLC+FRC
7.1 (Breitseite)
FL+FR+FC+LFE+FLC+FRC+SL+SR
achteckig
FL+FR+FC+BL+BR+BC+SL+SR
heruntermischen
DL+DR
Ein benutzerdefiniertes Channel-Layout kann als Folge von Begriffen angegeben werden, getrennt durch '+' oder '|'.
Jeder Begriff kann sein:
· der Name eines Standard-Kanal-Layouts (zB Mono, Stereo, 4.0, Quad (Vierleiter), 5.0, Usw.)
· der Name eines einzelnen Kanals (zB FL, FR, FC, LFE, Usw.)
· eine Anzahl von Kanälen, dezimal, optional gefolgt von 'c', was die Vorgabe ergibt
Kanallayout für diese Anzahl von Kanälen (siehe Funktion
"av_get_default_channel_layout")
· eine Kanal-Layout-Maske, hexadezimal beginnend mit "0x" (siehe Makros "AV_CH_*" in
libavutil/channel_layout.h.
Ab libavutil Version 53 das nachgestellte Zeichen "c", um eine Anzahl von
Kanäle werden benötigt, während eine Kanallayoutmaske auch als a . angegeben werden könnte
Dezimalzahl (wenn und nur wenn nicht gefolgt von "c").
Siehe auch die Funktion "av_get_channel_layout" definiert in libavutil/channel_layout.h.
AUSDRUCK BEWERTUNG
Beim Auswerten eines arithmetischen Ausdrucks verwendet FFmpeg einen internen Formelauswerter,
umgesetzt durch die libavutil/eval.h Schnittstelle.
Ein Ausdruck kann unäre, binäre Operatoren, Konstanten und Funktionen enthalten.
Zwei Ausdrücke Ausdruck1 und Ausdruck2 kann zu einem anderen Ausdruck kombiniert werden"Ausdruck1;Ausdruck2".
Ausdruck1 und Ausdruck2 werden der Reihe nach ausgewertet, und der neue Ausdruck ergibt den Wert von
Ausdruck2.
Folgende binäre Operatoren stehen zur Verfügung: "+", "-", "*", "/", "^".
Folgende unäre Operatoren stehen zur Verfügung: "+", "-".
Folgende Funktionen stehen zur Verfügung:
abs (x)
Absoluten Wert von berechnen x.
akos (x)
Berechne Arkuskosinus von x.
asin (x)
Berechne Arkussinus von x.
atan (x)
Berechne den Arkustangens von x.
zwischen(x, min max)
1 zurückgeben, wenn x ist größer oder gleich Min. und kleiner oder gleich max, 0
Andernfalls.
bitund(x, y)
bitor(x, y)
Bitweise berechnen und/oder Operation auf x und y.
Die Ergebnisse der Bewertung von x und y werden vor der Ausführung in ganze Zahlen umgewandelt
die bitweise Operation.
Beachten Sie, dass sowohl die Konvertierung in Integer als auch die Konvertierung zurück in Gleitkomma möglich sind
Präzision verlieren. Hüten Sie sich vor unerwarteten Ergebnissen für große Zahlen (normalerweise 2^53 und
größer).
Decke(ausdruck)
Runden Sie den Wert von expression ausdr aufwärts zur nächsten ganzen Zahl. Zum Beispiel,
"ceil(1.5)" ist "2.0".
Clip(x, min max)
Geben Sie den Wert von zurück x eingeklemmt zwischen Min. und max.
cos (x)
Kosinus von berechnen x.
Kosten (x)
Berechne den hyperbolischen Kosinus von x.
Gl(x, y)
1 zurückgeben, wenn x und y sind gleichwertig, sonst 0.
Erfahrung (x)
Exponential von berechnen x (mit Basis "e", der Eulerschen Zahl).
Etage (Ausdruck)
Runden Sie den Wert von expression ausdr abwärts auf die nächste ganze Zahl. Zum Beispiel,
"Etage(-1.5)" ist "-2.0".
Gauss (x)
Berechnen Sie die Gauss-Funktion von x, entsprechend "exp(-x*x/2) / sqrt(2*PI)".
gcd(x, y)
Gib den größten gemeinsamen Teiler von zurück x und y. Wenn beides x und y sind 0 oder eines oder beides
kleiner als Null sind, ist das Verhalten undefiniert.
gt(x, y)
1 zurückgeben, wenn x größer ist als y, 0 sonst.
gte(x, y)
1 zurückgeben, wenn x ist größer oder gleich y, 0 sonst.
hypot(x, y)
Diese Funktion ähnelt der C-Funktion mit demselben Namen; es gibt "sqrt(x*x +
y*y)", die Länge der Hypotenuse eines rechtwinkligen Dreiecks mit Seitenlängen x und y,
oder die Entfernung des Punktes (x, y) vom Ursprung.
wenn(x, y)
Bewerten x, und wenn das Ergebnis ungleich Null ist, das Ergebnis der Auswertung von zurückgeben y,
0 zurückgeben sonst.
wenn(x, y, z)
Bewerten x, und wenn das Ergebnis nicht null ist, geben Sie das Bewertungsergebnis von zurück y, Sonst
das Bewertungsergebnis von z.
wenn nicht (x, y)
Bewerten x, und wenn das Ergebnis Null ist, geben Sie das Ergebnis der Auswertung von zurück y, Rückkehr
0 sonst.
wenn nicht (x, y, z)
Bewerten x, und wenn das Ergebnis Null ist, geben Sie das Bewertungsergebnis von zurück y, ansonsten der
Bewertungsergebnis von z.
isinf(x)
1.0 zurückgeben, wenn x ist +/- UNENDLICH, sonst 0.0.
isnan (x)
1.0 zurückgeben, wenn x ist NAN, sonst 0.0.
ld(var)
Laden Sie den Wert der internen Variablen mit Zahl jung, die zuvor gespeichert wurde
mit st(jung, ausdr). Die Funktion gibt den geladenen Wert zurück.
log (x)
Berechnen des natürlichen Logarithmus von x.
lt(x, y)
1 zurückgeben, wenn x ist kleiner als y, 0 sonst.
lte(x, y)
1 zurückgeben, wenn x ist kleiner oder gleich y, 0 sonst.
max(x, y)
Gib das Maximum zwischen zurück x und y.
Luder, y)
Gib das Maximum zwischen zurück x und y.
mod(x, y)
Berechnen Sie den Rest der Division von x by y.
nicht(ausdruck)
1.0 zurückgeben, wenn ausdr ist null, sonst 0.0.
pow(x, y)
Berechnen Sie die Leistung von x erhöhten y, es ist äquivalent zu "(x)^(y). "
drucken(t)
drucken (t, l)
Drucken Sie den Wert des Ausdrucks t mit Loglevel l. Wenn l ist nicht angegeben, dann eine Voreinstellung
Log-Level verwendet wird. Gibt den Wert des gedruckten Ausdrucks zurück.
Druckt t mit Loglevel l
zufällig(x)
Gibt einen Pseudozufallswert zwischen 0.0 und 1.0 zurück. x ist der Index des internen
Variable, die verwendet wird, um den Seed/Zustand zu speichern.
root(ausdruck, max)
Suchen Sie einen Eingabewert, für den die durch . dargestellte Funktion ausdr mit Argument ld(0) is
0 im Intervall 0..max.
Der Ausdruck in ausdr muss eine stetige Funktion sein oder das Ergebnis ist undefiniert.
ld(0) wird verwendet, um den Funktionseingangswert darzustellen, was bedeutet, dass die gegebene
Ausdruck wird mehrmals mit verschiedenen Eingabewerten ausgewertet, die der
Ausdruck kann durch . zugreifen ld(0). Wenn der Ausdruck zu 0 ausgewertet wird, dann ist der
der entsprechende Eingabewert wird zurückgegeben.
sin (x)
Berechne den Sinus von x.
Geburt(x)
Berechne den hyperbolischen Sinus von x.
sqrt (ausdruck)
Berechne die Quadratwurzel von ausdr. Dies entspricht "(ausdr)^.5".
zerquetschen (x)
Berechne den Ausdruck "1/(1 + exp(4*x))".
st (var, Ausdruck)
Speichern Sie den Wert des Ausdrucks ausdr in einer internen Variablen. jung spezifiziert das
Nummer der Variablen, in der der Wert gespeichert werden soll, und es ist ein Wert im Bereich von 0 bis
9. Die Funktion gibt den in der internen Variablen gespeicherten Wert zurück. Hinweis, Variablen
werden derzeit nicht zwischen Ausdrücken geteilt.
tan (x)
Berechne den Tangens von x.
tan (x)
Berechne den hyperbolischen Tangens von x.
taylor(ausdruck, x)
taylor(ausdruck, x, Ich würde)
Bewerten Sie eine Taylor-Reihe bei x, gegeben einen Ausdruck, der das "ld(id)"-th darstellt
Ableitung einer Funktion bei 0.
Wenn die Reihe nicht konvergiert, ist das Ergebnis undefiniert.
ich tat) wird verwendet, um die Ableitungsordnung in . darzustellen ausdr, was bedeutet, dass das gegebene
Ausdruck wird mehrmals mit verschiedenen Eingabewerten ausgewertet, die der
Ausdruck kann über "ld(id)" zugreifen. Wenn id nicht angegeben ist, wird 0 angenommen.
Beachten Sie, wenn Sie die Ableitungen bei y anstelle von 0 haben, kann "taylor(expr, xy)" sein
benutzt.
Zeit(0)
Gibt die aktuelle Uhrzeit (Wanduhr) in Sekunden zurück.
trunc(ausdruck)
Runden Sie den Wert von expression ausdr gegen Null auf die nächste ganze Zahl. Zum Beispiel,
"trunc(-1.5)" ist "-1.0".
während(kond, Ausdruck)
Ausdruck auswerten ausdr während der Ausdruck cond ist ungleich Null und gibt den Wert zurück
des letzten ausdr Auswertung, oder NAN wenn cond war immer falsch.
Folgende Konstanten stehen zur Verfügung:
PI Bereich der Gerätescheibe, ca. 3.14
E exp(1) (Eulersche Zahl), ungefähr 2.718
PHI Goldener Schnitt (1+sqrt(5))/2, ungefähr 1.618
Angenommen, ein Ausdruck gilt als "wahr", wenn er einen Wert ungleich Null hat, beachten Sie Folgendes:
"*" funktioniert wie UND
"+" funktioniert wie OR
Zum Beispiel das Konstrukt:
wenn (A UND B) dann C
ist äquivalent zu:
wenn(A*B,C)
In Ihrem C-Code können Sie die Liste der unären und binären Funktionen erweitern und definieren
erkannten Konstanten, damit sie für Ihre Ausdrücke zur Verfügung stehen.
Der Bewerter erkennt auch die Einheitenpräfixe des Internationalen Systems. Wenn 'i' angehängt wird
nach dem Präfix werden binäre Präfixe verwendet, die auf Potenzen von 1024 statt basieren
Potenzen von 1000. Das Postfix 'B' multipliziert den Wert mit 8 und kann nach a . angehängt werden
Einheitenpräfix oder allein verwendet. Dies ermöglicht beispielsweise die Verwendung von 'KB', 'MiB', 'G' und 'B' als
Nummer postfix.
Es folgt die Liste der verfügbaren Präfixe des Internationalen Systems mit Angabe der
entsprechende Potenzen von 10 und 2.
y 10^-24 / 2^-80
z 10^-21 / 2^-70
a 10^-18 / 2^-60
f 10^-15 / 2^-50
p 10^-12 / 2^-40
n 10^-9 / 2^-30
u 10^-6 / 2^-20
m 10^-3 / 2^-10
c 10 ^ -2
d 10 ^ -1
h 10 ^ 2
k 10^3 / 2^10
K 10^3 / 2^10
M 10^6 / 2^20
G 10^9 / 2^30
T 10^12 / 2^40
P 10^15 / 2^40
E 10^18 / 2^50
Z 10^21 / 2^60
Y 10^24 / 2^70
OFFENCL OPTIONAL
Wenn FFmpeg mit "--enable-opencl" konfiguriert ist, ist es möglich, die Optionen für
den globalen OpenCL-Kontext.
Die Liste der unterstützten Optionen folgt:
build_options
Legen Sie Build-Optionen fest, die zum Kompilieren der registrierten Kernel verwendet werden.
Siehe Referenz "OpenCL Specification Version: 1.2 Kapitel 5.6.4".
plattform_idx
Wählen Sie den Index der Plattform aus, um OpenCL-Code auszuführen.
Der angegebene Index muss einer der Indizes in der Geräteliste sein, die
erhalten mit "ffmpeg -opencl_bench" oder "av_opencl_get_device_list()".
Geräte-IDX
Wählen Sie den Index des Geräts aus, das zum Ausführen von OpenCL-Code verwendet wird.
Der angegebene Index muss einer der Indizes in der Geräteliste sein, die
erhalten mit "ffmpeg -opencl_bench" oder "av_opencl_get_device_list()".
CODEC OPTIONAL
libavcodec bietet einige generische globale Optionen, die auf allen Encodern eingestellt werden können und
Decoder. Darüber hinaus kann jeder Codec sogenannte private Optionen unterstützen, die spezifisch sind
für einen bestimmten Codec.
Manchmal wirkt sich eine globale Option nur auf eine bestimmte Art von Codec aus und kann
Unsinnig oder ignoriert von anderen, daher müssen Sie sich der Bedeutung des angegebenen Begriffs bewusst sein
Optionen. Außerdem sind einige Optionen nur zum Dekodieren oder Kodieren gedacht.
Optionen können eingestellt werden durch Angabe von -zu erhalten Wert in den FFmpeg-Tools oder durch Einstellen der
Wert explizit in den "AVCodecContext"-Optionen oder über die libavutil/opt.h API für
programmatische Verwendung.
Die Liste der unterstützten Optionen folgt:
b ganze Zahl (Kodierung, Audio, Video)
Bitrate in Bit/s einstellen. Der Standardwert ist 200 KB.
ab ganze Zahl (Kodierung, Audio)
Stellen Sie die Audio-Bitrate ein (in Bits/s). Der Standardwert ist 128K.
bt ganze Zahl (Kodierung, Video)
Stellen Sie die Video-Bitratentoleranz ein (in Bits/s). Im 1-Pass-Modus spezifiziert die Bitratentoleranz
wie weit die Ratensteuerung bereit ist, vom durchschnittlichen Zielwert der Bitrate abzuweichen. Dies
hat nichts mit der min/max Bitrate zu tun. Eine zu starke Verminderung der Toleranz wirkt sich negativ aus
auf Qualität.
Fahnen Fahnen (Dekodierung/Kodierung,Audio,Video,Untertitel)
Legen Sie generische Flags fest.
Mögliche Werte:
mv4 Verwenden Sie vier Bewegungsvektoren pro Makroblock (mpeg4).
qpel
Verwenden Sie eine 1/4-Pel-Bewegungskompensation.
Schleife
Schleifenfilter verwenden.
qskala
Verwenden Sie eine feste qscale.
gmc Verwenden Sie gmc.
mv0 Versuchen Sie immer ein mb mit mv=<0,0>.
input_konserviert
pass1
Verwenden Sie die interne 2-Pass-Ratensteuerung im First-Pass-Modus.
pass2
Verwenden Sie die interne 2-Pass-Ratensteuerung im Second-Pass-Modus.
grau
Nur Graustufen dekodieren/kodieren.
emu_edge
Zeichnen Sie keine Kanten.
Psnr
Setzen Sie beim Codieren error[?]-Variablen.
gekürzt
NAQ Normalisieren Sie die adaptive Quantisierung.
ildct
Verwenden Sie Interlaced-DCT.
niedrige_verzögerung
Niedrige Verzögerung erzwingen.
global_header
Platzieren Sie globale Header in Extradaten anstelle jedes Keyframes.
bitexakt
Schreiben Sie nur plattform-, build- und zeitunabhängige Daten. (außer (I)DCT). Dies
stellt sicher, dass Datei- und Datenprüfsummen reproduzierbar sind und zwischen Plattformen übereinstimmen.
Seine primäre Verwendung ist für Regressionstests.
aic Wenden Sie H263 Advanced Intra-Codierung / MPEG4-AC-Vorhersage an.
Cbp Veraltet, verwenden Sie stattdessen private MPEGvideo-Optionen.
qprd
Veraltet, verwenden Sie stattdessen private MPEGvideo-Optionen.
Schlinge
Wenden Sie die Interlaced-Bewegungsschätzung an.
cgop
Verwenden Sie geschlossene Gop.
me_method ganze Zahl (Kodierung, Video)
Bewegungsschätzungsmethode einstellen.
Mögliche Werte:
Null
Nullbewegungsschätzung (am schnellsten)
voller
Vollbewegungsschätzung (am langsamsten)
epz
EPZS-Bewegungsschätzung (Standard)
esa esa Bewegungsschätzung (Alias für voll)
tesa
tesa Bewegungsschätzung
Tag dia Bewegungsschätzung (Alias für epzs)
Log Bewegungsschätzung protokollieren
Phods
phods bewegungsschätzung
x1 X1-Bewegungsschätzung
hex Hex-Bewegungsschätzung
ähm umh Bewegungsschätzung
Prozess
Iter-Bewegungsschätzung
extradata_size ganze Zahl
Legen Sie die Größe der Extradaten fest.
Zeitbasis rational Anzahl
Codec-Zeitbasis einstellen.
Es ist die grundlegende Zeiteinheit (in Sekunden), für die Frame-Zeitstempel verwendet werden
repräsentiert. Bei Inhalten mit fester fps sollte die Zeitbasis "1/frame_rate" und der Zeitstempel sein
Inkremente sollten identisch sein 1.
g ganze Zahl (Kodierung, Video)
Legen Sie die Bildgröße der Gruppe fest. Der Standardwert ist 12.
ar ganze Zahl (Dekodierung/Kodierung, Audio)
Stellen Sie die Audio-Abtastrate (in Hz) ein.
ac ganze Zahl (Dekodierung/Kodierung, Audio)
Stellen Sie die Anzahl der Audiokanäle ein.
Cutoff- ganze Zahl (Kodierung, Audio)
Cutoff-Bandbreite einstellen.
Rahmengröße ganze Zahl (Kodierung, Audio)
Stellen Sie die Audio-Frame-Größe ein.
Jeder eingereichte Frame mit Ausnahme des letzten muss genau frame_size Samples pro . enthalten
Kanal. Kann 0 sein, wenn der Codec in diesem Fall CODEC_CAP_VARIABLE_FRAME_SIZE gesetzt hat
die Rahmengröße ist nicht eingeschränkt. Es wird von einigen Decodern eingestellt, um konstant anzuzeigen
Rahmengröße.
Rahmennummer ganze Zahl
Stellen Sie die Bildnummer ein.
verzögern ganze Zahl
qkomp schweben (Kodierung, Video)
Stellen Sie die Videoquantizer-Skalierungskompression (VBR) ein. Es wird als Konstante im verwendet
Ratecontrol-Gleichung. Empfohlener Bereich für Standard rc_eq: 0.0-1.0.
qblur schweben (Kodierung, Video)
Stellen Sie die Unschärfe der Videoquantisierungsskala (VBR) ein.
qmin ganze Zahl (Kodierung, Video)
Stellen Sie die minimale Videoquantisierungsskala (VBR) ein. Muss zwischen -1 und 69 enthalten sein, Standardwert
ist 2.
qmax ganze Zahl (Kodierung, Video)
Stellen Sie die maximale Videoquantisierungsskala (VBR) ein. Muss zwischen -1 und 1024 enthalten sein, Standardeinstellung
Wert ist 31.
qdiff ganze Zahl (Kodierung, Video)
Stellen Sie die maximale Differenz zwischen der Quantisierungsskala (VBR) ein.
bf ganze Zahl (Kodierung, Video)
Legen Sie die maximale Anzahl von B-Frames zwischen Nicht-B-Frames fest.
Muss eine ganze Zahl zwischen -1 und 16 sein. 0 bedeutet, dass B-Frames deaktiviert sind. Wenn ein Wert
von -1 verwendet wird, wird je nach Encoder ein automatischer Wert gewählt.
Der Standardwert ist 0.
b_qfaktor schweben (Kodierung, Video)
Stellen Sie den qp-Faktor zwischen P- und B-Frames ein.
rc_strategie ganze Zahl (Kodierung, Video)
Ratecontrol-Methode einstellen.
b_strategie ganze Zahl (Kodierung, Video)
Legen Sie die Strategie fest, um zwischen I/P/B-Frames zu wählen.
ps ganze Zahl (Kodierung, Video)
Legen Sie die RTP-Nutzlastgröße in Byte fest.
mv_bits ganze Zahl
header_bits ganze Zahl
i_tex_bits ganze Zahl
p_tex_bits ganze Zahl
ich zähle ganze Zahl
p_count ganze Zahl
überspringen_count ganze Zahl
misc_bits ganze Zahl
Frame_Bits ganze Zahl
Codec-Tag ganze Zahl
Fehler Fahnen (Dekodierung, Video)
Problemumgehung nicht automatisch erkannte Encoder-Fehler.
Mögliche Werte:
AutoDetect
old_msmpeg4
einige alte lavc generierte msmpeg4v3-Dateien (keine automatische Erkennung)
xvid_ilace
Xvid-Interlacing-Fehler (automatisch erkannt, wenn fourcc==XVIX)
ump4
(automatisch erkannt, wenn fourcc==UMP4)
no_padding
Füllfehler (automatisch erkannt)
amv
ac_vlc
Illegaler vlc-Bug (automatisch pro Fourcc erkannt)
qpel_chroma
std_qpel
altes Standard-qpel (automatisch erkannt pro Fourcc/Version)
qpel_chroma2
direct_blocksize
direct-qpel-blocksize-Bug (automatisch pro Fourcc/Version erkannt)
Rand
Edge-Padding-Fehler (automatisch pro Fourcc/Version erkannt)
hpel_chroma
dc_clip
ms Umgehung verschiedener Fehler in defekten Microsoft-Decodern.
trunk
transkribierte Rahmen
Lelim ganze Zahl (Kodierung, Video)
Legen Sie den Schwellenwert für die Eliminierung eines einzelnen Koeffizienten für die Luminanz fest (auch negative Werte)
DC-Koeffizient berücksichtigen).
Celim ganze Zahl (Kodierung, Video)
Legen Sie den Schwellenwert für die Eliminierung eines einzelnen Koeffizienten für die Chrominanz fest (auch negative Werte)
DC-Koeffizient berücksichtigen)
streng ganze Zahl (Dekodierung/Kodierung, Audio, Video)
Geben Sie an, wie strikt die Standards befolgt werden sollen.
Mögliche Werte:
sehr
strikt einer älteren, strengeren Version der Spezifikation oder Referenzsoftware entsprechen
streng
Halten Sie sich strikt an alle Dinge in der Spezifikation, unabhängig von den Konsequenzen
normal
inoffiziell
inoffizielle Erweiterungen zulassen
experimentell
erlauben nicht standardisierte experimentelle Dinge, experimentell (unfertig/in Arbeit)
Fortschritt/nicht gut getestet) Decoder und Encoder. Hinweis: Experimentelle Decoder können
ein Sicherheitsrisiko darstellen, verwenden Sie dies nicht zum Decodieren nicht vertrauenswürdiger Eingaben.
b_qoffset schweben (Kodierung, Video)
Stellen Sie den QP-Offset zwischen P- und B-Frames ein.
err_detect Fahnen (Dekodierung, Audio, Video)
Setzen Sie Fehlererkennungs-Flags.
Mögliche Werte:
crccheck
eingebettete CRCs überprüfen
Bitstream
Abweichungen der Bitstream-Spezifikation erkennen
puffern
unpassende Bitstream-Länge erkennen
explodieren
Decodierung bei Erkennung kleiner Fehler abbrechen
Ignoriere_err
Ignorieren Sie Decodierungsfehler und fahren Sie mit der Decodierung fort. Dies ist nützlich, wenn Sie möchten
analysieren den Inhalt eines Videos und möchten daher, dass alles dekodiert wird, egal,
was. Diese Option führt nicht zu einem Video, das im Fall von . angenehm anzusehen ist
Fehler.
vorsichtig
Betrachten Sie Dinge, die gegen die Spezifikation verstoßen und in der Wildnis nicht als Fehler angesehen wurden
konform
Betrachten Sie alle Nichteinhaltungen der Spezifikationen als Fehler
aggressiv
Betrachten Sie Dinge, die ein vernünftiger Encoder nicht tun sollte, als Fehler
has_b_frames ganze Zahl
block_align ganze Zahl
mpeg_quant ganze Zahl (Kodierung, Video)
Verwenden Sie MPEG-Quantisierer anstelle von H.263.
qsquish schweben (Kodierung, Video)
So halten Sie den Quantisierer zwischen qmin und qmax (0 = Clip, 1 = Use Differentiable
Funktion).
rc_qmod_amp schweben (Kodierung, Video)
Stellen Sie die experimentelle Quantisierungsmodulation ein.
rc_qmod_freq ganze Zahl (Kodierung, Video)
Stellen Sie die experimentelle Quantisierungsmodulation ein.
rc_override_count ganze Zahl
rc_eq Schnur (Kodierung, Video)
Stellen Sie die Geschwindigkeitsregelungsgleichung ein. Bei der Berechnung des Ausdrucks wird neben dem Standard
Funktionen, die im Abschnitt 'Auswertung von Ausdrücken' definiert wurden, sind die folgenden Funktionen:
verfügbar: bits2qp(bits), qp2bits(qp). Außerdem stehen folgende Konstanten zur Verfügung:
iTex pTex tex mv fCode iCount mcVar var isI isP isB avgQP qComp avgIITex avgPITex
avgPPTex avgBPTex avgTex.
Maximale Rate ganze Zahl (Kodierung, Audio, Video)
Legen Sie die maximale Bitratentoleranz fest (in Bits/s). Erfordert die Einstellung von Bufsize.
Minrate ganze Zahl (Kodierung, Audio, Video)
Stellen Sie die minimale Bitratentoleranz ein (in Bits/s). Am nützlichsten beim Einrichten einer CBR-Kodierung. es ist
sonst wenig zu gebrauchen.
Puffergröße ganze Zahl (Kodierung, Audio, Video)
Legen Sie die Puffergröße für die Ratensteuerung fest (in Bit).
rc_buf_aggressivität schweben (Kodierung, Video)
Derzeit nutzlos.
i_qfaktor schweben (Kodierung, Video)
Stellen Sie den QP-Faktor zwischen P- und I-Frames ein.
i_qoffset schweben (Kodierung, Video)
Stellen Sie den QP-Offset zwischen P- und I-Frames ein.
rc_init_cplx schweben (Kodierung, Video)
Legen Sie die anfängliche Komplexität für die 1-Pass-Codierung fest.
dct ganze Zahl (Kodierung, Video)
DCT-Algorithmus einstellen.
Mögliche Werte:
Auto
Automatisch einen guten auswählen (Standard)
fastint
schnelle ganze Zahl
int genaue ganze Zahl
MMX
altivec
Fan
Gleitkomma AAN DCT
lumi_maske schweben (Kodierung, Video)
Komprimieren Sie helle Bereiche stärker als mittlere.
tcplx_mask schweben (Kodierung, Video)
Legen Sie die Maskierung der zeitlichen Komplexität fest.
scplx_maske schweben (Kodierung, Video)
Legen Sie die Maskierung der räumlichen Komplexität fest.
p_maske schweben (Kodierung, Video)
Stellen Sie die Intermaskierung ein.
dunkle_maske schweben (Kodierung, Video)
Komprimieren Sie dunkle Bereiche stärker als mittlere.
idct ganze Zahl (Dekodierung/Kodierung, Video)
Wählen Sie IDCT-Implementierung aus.
Mögliche Werte:
Auto
int
einfach
einfachmmx
einfachauto
Wählen Sie automatisch ein IDCT aus, das mit dem einfachen kompatibel ist
Arm
altivec
sh4
einfacher Arm
simplearmv5te
simplearmv6
simpleneon
einfachealpha
ipp
xvidmmx
faani
Gleitkomma-AAN IDCT
Slice_count ganze Zahl
ec Fahnen (Dekodierung, Video)
Legen Sie eine Strategie zur Fehlerverbergung fest.
Mögliche Werte:
rate_mvs
iterative Bewegungsvektor (MV)-Suche (langsam)
deblockieren
Verwenden Sie einen starken Deblock-Filter für beschädigte MBs
favor_inter
Bevorzugen Sie die Vorhersage aus dem vorherigen Frame anstelle des aktuellen
bits_per_coded_sample ganze Zahl
pred ganze Zahl (Kodierung, Video)
Vorhersagemethode festlegen.
Mögliche Werte:
links
Ebene
mittlere
Aussehen rational Anzahl (Kodierung, Video)
Stellen Sie das Seitenverhältnis des Beispiels ein.
debuggen Fahnen (Dekodierung/Kodierung,Audio,Video,Untertitel)
Drucken Sie spezifische Debug-Informationen.
Mögliche Werte:
Bild
Bildinfo
rc Ratenkontrolle
Bitstream
mb_typ
Makroblock (MB) Typ
qp Quantisierungsparameter pro Block (QP)
mv Bewegungsvektor
dct_coeff
grüne_metadaten
Komplexitätsmetadaten für den kommenden Frame, GoP oder für eine bestimmte Dauer anzeigen.
überspringen
Startcode
pts
er Fehlererkennung
mmco
Steuervorgänge für die Speicherverwaltung (H.264)
Bugs
vis_qp
Quantisierungsparameter (QP) visualisieren, niedrigere QP werden grüner getönt
vis_mb_type
Blocktypen visualisieren
Puffer
Bildpufferzuweisungen
thread_ops
Einfädelvorgänge
nomc
Bewegungskompensation überspringen
vismv ganze Zahl (Dekodierung, Video)
Visualisieren Sie Bewegungsvektoren (MVs).
Diese Option ist veraltet, siehe stattdessen den Codecview-Filter.
Mögliche Werte:
pf vorwärts vorhergesagte MVs von P-Frames
bf vorwärts vorhergesagte MVs von B-Frames
bb rückwärts vorhergesagte MVs von B-Frames
CMP ganze Zahl (Kodierung, Video)
Stellen Sie die vollständige Vergleichsfunktion ein.
Mögliche Werte:
traurig Summe der absoluten Differenzen, schnell (Standard)
sse Summe der quadrierten Fehler
satt
Summe der absoluten Hadamard-transformierten Differenzen
dct Summe der absoluten DCT-transformierten Differenzen
Psnr
Summe der quadrierten Quantisierungsfehler (vermeiden, geringe Qualität)
Bit Anzahl der für den Block benötigten Bits
rd Geschwindigkeitsverzerrung optimal, langsam
Null
0
vsad
Summe der absoluten Höhenunterschiede
vsse
Summe der quadrierten vertikalen Differenzen
nss
rauscherhaltende Summe der quadrierten Differenzen
w53 5/3 Wavelet, nur im Schnee verwendet
w97 9/7 Wavelet, nur im Schnee verwendet
dktmax
Chroma
subcmp ganze Zahl (Kodierung, Video)
Stellen Sie die Sub-Pel-Me-Vergleichsfunktion ein.
Mögliche Werte:
traurig Summe der absoluten Differenzen, schnell (Standard)
sse Summe der quadrierten Fehler
satt
Summe der absoluten Hadamard-transformierten Differenzen
dct Summe der absoluten DCT-transformierten Differenzen
Psnr
Summe der quadrierten Quantisierungsfehler (vermeiden, geringe Qualität)
Bit Anzahl der für den Block benötigten Bits
rd Geschwindigkeitsverzerrung optimal, langsam
Null
0
vsad
Summe der absoluten Höhenunterschiede
vsse
Summe der quadrierten vertikalen Differenzen
nss
rauscherhaltende Summe der quadrierten Differenzen
w53 5/3 Wavelet, nur im Schnee verwendet
w97 9/7 Wavelet, nur im Schnee verwendet
dktmax
Chroma
mbcmp ganze Zahl (Kodierung, Video)
Stellen Sie die Makroblock-Vergleichsfunktion ein.
Mögliche Werte:
traurig Summe der absoluten Differenzen, schnell (Standard)
sse Summe der quadrierten Fehler
satt
Summe der absoluten Hadamard-transformierten Differenzen
dct Summe der absoluten DCT-transformierten Differenzen
Psnr
Summe der quadrierten Quantisierungsfehler (vermeiden, geringe Qualität)
Bit Anzahl der für den Block benötigten Bits
rd Geschwindigkeitsverzerrung optimal, langsam
Null
0
vsad
Summe der absoluten Höhenunterschiede
vsse
Summe der quadrierten vertikalen Differenzen
nss
rauscherhaltende Summe der quadrierten Differenzen
w53 5/3 Wavelet, nur im Schnee verwendet
w97 9/7 Wavelet, nur im Schnee verwendet
dktmax
Chroma
ildctcmp ganze Zahl (Kodierung, Video)
Stellen Sie die Interlaced-DCT-Vergleichsfunktion ein.
Mögliche Werte:
traurig Summe der absoluten Differenzen, schnell (Standard)
sse Summe der quadrierten Fehler
satt
Summe der absoluten Hadamard-transformierten Differenzen
dct Summe der absoluten DCT-transformierten Differenzen
Psnr
Summe der quadrierten Quantisierungsfehler (vermeiden, geringe Qualität)
Bit Anzahl der für den Block benötigten Bits
rd Geschwindigkeitsverzerrung optimal, langsam
Null
0
vsad
Summe der absoluten Höhenunterschiede
vsse
Summe der quadrierten vertikalen Differenzen
nss
rauscherhaltende Summe der quadrierten Differenzen
w53 5/3 Wavelet, nur im Schnee verwendet
w97 9/7 Wavelet, nur im Schnee verwendet
dktmax
Chroma
dia_size ganze Zahl (Kodierung, Video)
Stellen Sie Diamanttyp und -größe für die Bewegungsschätzung ein.
last_pred ganze Zahl (Kodierung, Video)
Stellen Sie die Anzahl der Bewegungsprädiktoren aus dem vorherigen Frame ein.
Prämie ganze Zahl (Kodierung, Video)
Stellen Sie die Vorausschätzung der Bewegung ein.
vorkomp ganze Zahl (Kodierung, Video)
Stellen Sie die Vergleichsfunktion vor der Bewegungsschätzung ein.
Mögliche Werte:
traurig Summe der absoluten Differenzen, schnell (Standard)
sse Summe der quadrierten Fehler
satt
Summe der absoluten Hadamard-transformierten Differenzen
dct Summe der absoluten DCT-transformierten Differenzen
Psnr
Summe der quadrierten Quantisierungsfehler (vermeiden, geringe Qualität)
Bit Anzahl der für den Block benötigten Bits
rd Geschwindigkeitsverzerrung optimal, langsam
Null
0
vsad
Summe der absoluten Höhenunterschiede
vsse
Summe der quadrierten vertikalen Differenzen
nss
rauscherhaltende Summe der quadrierten Differenzen
w53 5/3 Wavelet, nur im Schnee verwendet
w97 9/7 Wavelet, nur im Schnee verwendet
dktmax
Chroma
pre_dia_size ganze Zahl (Kodierung, Video)
Stellen Sie Diamanttyp und -größe für den Vorlauf zur Bewegungsschätzung ein.
unterq ganze Zahl (Kodierung, Video)
Stellen Sie die Qualität der Schätzung der Sub-Pel-Bewegung ein.
dtg_active_format ganze Zahl
me_range ganze Zahl (Kodierung, Video)
Begrenzen Sie den Bewegungsvektorbereich (1023 für DivX-Player).
ibis ganze Zahl (Kodierung, Video)
Legen Sie den Intra-Quant-Bias fest.
pbias ganze Zahl (Kodierung, Video)
Legen Sie den Inter-Quant-Bias fest.
color_table_id ganze Zahl
globale_qualität ganze Zahl (Kodierung, Audio, Video)
Coder ganze Zahl (Kodierung, Video)
Mögliche Werte:
vlc Codierer mit variabler Länge / Huffman-Codierer
ac arithmetischer Coder
roh raw (keine Kodierung)
rle Lauflängencodierer
deflate
Deflate-basierter Coder
Kontext ganze Zahl (Kodierung, Video)
Kontextmodell festlegen.
Slice_Flags ganze Zahl
xvmc_acceleration ganze Zahl
mbd ganze Zahl (Kodierung, Video)
Legen Sie den Makroblock-Entscheidungsalgorithmus fest (Hochqualitätsmodus).
Mögliche Werte:
einfach
mbcmp verwenden (Standard)
Bits
am wenigsten Bits verwenden
rd beste Ratenverzerrung verwenden
stream_codec_tag ganze Zahl
sc_threshold ganze Zahl (Kodierung, Video)
Stellen Sie den Schwellenwert für den Szenenwechsel ein.
min ganze Zahl (Kodierung, Video)
Stellen Sie den minimalen Lagrange-Faktor (VBR) ein.
lmax ganze Zahl (Kodierung, Video)
Stellen Sie den maximalen Verzögerungsfaktor (VBR) ein.
nr ganze Zahl (Kodierung, Video)
Rauschunterdrückung einstellen.
rc_init_occupancy ganze Zahl (Kodierung, Video)
Legen Sie die Anzahl der Bits fest, die in den RC-Puffer geladen werden sollen, bevor die Decodierung beginnt.
flags2 Fahnen (Dekodierung/Kodierung, Audio, Video)
Mögliche Werte:
schnell
Erlaube nicht spezifikationskonforme Beschleunigungstricks.
schop
Veraltet, verwenden Sie stattdessen private MPEGvideo-Optionen.
nein
Bitstream-Codierung überspringen.
ignorieren
Ignorieren Sie die Zuschneideinformationen von sps.
local_header
Platzieren Sie globale Header bei jedem Keyframe statt in Extradaten.
Stücke
Frame-Daten können in mehrere Blöcke aufgeteilt werden.
zeige alles
Alle Frames vor dem ersten Keyframe anzeigen.
Skiprd
Veraltet, verwenden Sie stattdessen private MPEGvideo-Optionen.
export_mvs
Bewegungsvektoren in Frame-Seitendaten exportieren (siehe "AV_FRAME_DATA_MOTION_VECTORS")
für Codecs, die es unterstützen. Siehe auch doc/examples/export_mvs.c.
Fehler ganze Zahl (Kodierung, Video)
qns ganze Zahl (Kodierung, Video)
Veraltet, verwenden Sie stattdessen private MPEGvideo-Optionen.
Themen ganze Zahl (Dekodierung/Kodierung, Video)
Mögliche Werte:
Auto
eine gute Anzahl von Threads erkennen
me_threshold ganze Zahl (Kodierung, Video)
Legen Sie den Schwellenwert für die Bewegungsschätzung fest.
mb_threshold ganze Zahl (Kodierung, Video)
Legen Sie den Makroblock-Schwellenwert fest.
dc ganze Zahl (Kodierung, Video)
Legen Sie intra_dc_precision fest.
nssw ganze Zahl (Kodierung, Video)
Stellen Sie das nsse-Gewicht ein.
überspringen_top ganze Zahl (Dekodierung, Video)
Legen Sie die Anzahl der Makroblockzeilen oben fest, die übersprungen werden.
überspringen_bottom ganze Zahl (Dekodierung, Video)
Legen Sie die Anzahl der Makroblockzeilen unten fest, die übersprungen werden.
profile ganze Zahl (Kodierung, Audio, Video)
Mögliche Werte:
unbekannt
aac_main
aac_low
aac_ssr
aac_ltp
aac_he
aac_he_v2
aac_ld
aac_feld
mpeg2_aac_low
mpeg2_aac_he
mpeg4_sp
mpeg4_core
mpeg4_main
mpeg4_asp
dts
dts_es
dts_96_24
dts_hd_hra
dts_hd_ma
Grad des ganze Zahl (Kodierung, Audio, Video)
Mögliche Werte:
unbekannt
niedrige Auflösung ganze Zahl (Dekodierung, Audio, Video)
Decodieren Sie mit 1= 1/2, 2=1/4, 3=1/8 Auflösungen.
überspringen_threshold ganze Zahl (Kodierung, Video)
Stellen Sie den Schwellenwert für das Überspringen von Bildern ein.
überspringen_Faktor ganze Zahl (Kodierung, Video)
Stellen Sie den Frame-Skip-Faktor ein.
überspringen_exp ganze Zahl (Kodierung, Video)
Stellen Sie den Exponenten für das Überspringen von Frames ein. Negative Werte verhalten sich identisch mit den entsprechenden
positive, außer dass die Punktzahl normalisiert ist. Positive Werte gibt es in erster Linie
aus Kompatibilitätsgründen und sind nicht so nützlich.
überspringencmp ganze Zahl (Kodierung, Video)
Stellen Sie die Vergleichsfunktion zum Überspringen von Bildern ein.
Mögliche Werte:
traurig Summe der absoluten Differenzen, schnell (Standard)
sse Summe der quadrierten Fehler
satt
Summe der absoluten Hadamard-transformierten Differenzen
dct Summe der absoluten DCT-transformierten Differenzen
Psnr
Summe der quadrierten Quantisierungsfehler (vermeiden, geringe Qualität)
Bit Anzahl der für den Block benötigten Bits
rd Geschwindigkeitsverzerrung optimal, langsam
Null
0
vsad
Summe der absoluten Höhenunterschiede
vsse
Summe der quadrierten vertikalen Differenzen
nss
rauscherhaltende Summe der quadrierten Differenzen
w53 5/3 Wavelet, nur im Schnee verwendet
w97 9/7 Wavelet, nur im Schnee verwendet
dktmax
Chroma
border_mask schweben (Kodierung, Video)
Erhöhen Sie den Quantisierer für Makroblöcke in der Nähe von Rändern.
mblmin ganze Zahl (Kodierung, Video)
Stellen Sie den minimalen Makroblock-Lagrange-Faktor (VBR) ein.
mblmax ganze Zahl (Kodierung, Video)
Legen Sie den maximalen Makroblock-Lagrange-Faktor (VBR) fest.
mepc ganze Zahl (Kodierung, Video)
Stellen Sie die Bitratenkompensation für die Bewegungsschätzung ein (1.0 = 256).
skip_loop_filter ganze Zahl (Dekodierung, Video)
skip_idct ganze Zahl (Dekodierung, Video)
überspringen_frame ganze Zahl (Dekodierung, Video)
Lassen Sie den Decoder die Verarbeitung je nach dem mit der Option ausgewählten Rahmentyp verwerfen
Wert.
skip_loop_filter überspringt die Frame-Loop-Filterung, skip_idct überspringt Frame
IDCT/Dequantisierung, überspringen_frame überspringt die Dekodierung.
Mögliche Werte:
keine
Kein Rahmen verwerfen.
Standard
Verwerfen Sie nutzlose Rahmen wie Rahmen der Größe 0.
noref
Verwerfen Sie alle Nicht-Referenz-Frames.
bidir
Alle bidirektionalen Frames verwerfen.
kein Schlüssel
Alle Frames außer Keyframes verwerfen.
alle Verwerfen Sie alle Frames.
Standardwert ist Standard.
bidir_refine ganze Zahl (Kodierung, Video)
Verfeinern Sie die beiden Bewegungsvektoren, die in bidirektionalen Makroblöcken verwendet werden.
brd_scale ganze Zahl (Kodierung, Video)
Downscale-Frames für dynamische B-Frame-Entscheidung.
keyint_min ganze Zahl (Kodierung, Video)
Legen Sie das Mindestintervall zwischen den IDR-Frames fest.
Ref ganze Zahl (Kodierung, Video)
Legen Sie Referenzframes fest, die für die Bewegungskompensation berücksichtigt werden sollen.
Chroma-Offset ganze Zahl (Kodierung, Video)
Stellen Sie den Chroma-qp-Offset von Luma ein.
Gitter ganze Zahl (Kodierung, Audio, Video)
Stellen Sie die optimale Quantisierung für die Geschwindigkeitsverzerrung ein.
sc_faktor ganze Zahl (Kodierung, Video)
Setzen Sie den Wert multipliziert mit qscale für jeden Frame und addieren Sie ihn zu scene_change_score.
mv0_threshold ganze Zahl (Kodierung, Video)
b_empfindlichkeit ganze Zahl (Kodierung, Video)
Passen Sie die Empfindlichkeit von b_frame_strategy 1 an.
Kompressionslevel ganze Zahl (Kodierung, Audio, Video)
min_prediction_order ganze Zahl (Kodierung, Audio)
max_prediction_order ganze Zahl (Kodierung, Audio)
timecode_frame_start ganze Zahl (Kodierung, Video)
Legen Sie die Startnummer des GOP-Timecode-Frames im Non-Drop-Frame-Format fest.
Anfragekanäle ganze Zahl (Dekodierung, Audio)
Stellen Sie die gewünschte Anzahl von Audiokanälen ein.
bits_per_raw_sample ganze Zahl
Kanal_Layout ganze Zahl (Dekodierung/Kodierung, Audio)
Mögliche Werte:
request_channel_layout ganze Zahl (Dekodierung, Audio)
Mögliche Werte:
rc_max_vbv_use schweben (Kodierung, Video)
rc_min_vbv_use schweben (Kodierung, Video)
ticks_per_frame ganze Zahl (Dekodierung/Kodierung, Audio, Video)
color_primaries ganze Zahl (Dekodierung/Kodierung, Video)
color_trc ganze Zahl (Dekodierung/Kodierung, Video)
Farbraum ganze Zahl (Dekodierung/Kodierung, Video)
Farbspektrum ganze Zahl (Dekodierung/Kodierung, Video)
Als Eingabeparameter dient er als Hinweis für den Decoder, welcher Farbbereich der
Eingang hat.
chroma_sample_location ganze Zahl (Dekodierung/Kodierung, Video)
log_level_offset ganze Zahl
Legen Sie den Log-Level-Offset fest.
Scheiben ganze Zahl (Kodierung, Video)
Anzahl der Slices, die bei der parallelisierten Codierung verwendet werden.
Gewindetyp Fahnen (Dekodierung/Kodierung, Video)
Wählen Sie aus, welche Multithreading-Methoden verwendet werden sollen.
Gebrauch von Rahmen wird die Decodierungsverzögerung um einen Frame pro Thread erhöhen, sodass Clients, die
keine zukünftigen Frames bereitstellen kann, sollte es nicht verwenden.
Mögliche Werte:
Scheibe
Dekodieren Sie mehr als einen Teil eines einzelnen Frames auf einmal.
Multithreading mit Slices funktioniert nur, wenn das Video mit Slices codiert wurde.
Rahmen
Decodieren Sie mehr als einen Frame gleichzeitig.
Standardwert ist Scheibe+Rahmen.
audio_service_type ganze Zahl (Kodierung, Audio)
Legen Sie den Audiodiensttyp fest.
Mögliche Werte:
ma Hauptaudiodienst
ef Effekte
vi Sehbehindert
hi Hörgeschädigt
di Dialog
co Kommentar
em Notfall
vo Voice Over
ka Karaoke
request_sample_fmt sample_fmt (Dekodierung, Audio)
Set-Sample-Format-Audio-Decoder sollten das bevorzugen. Der Standardwert ist "keiner".
pkt_timebase rational Anzahl
sub_charenc Codierung (Dekodierung, Untertitel)
Legen Sie die Zeichenkodierung für die eingegebenen Untertitel fest.
Feldreihenfolge Feldreihenfolge (Video)
Festlegen/Überschreiben der Halbbildreihenfolge des Videos. Mögliche Werte:
fortschrittlich
Progressives Video
tt Interlaced-Video, oberes Halbbild codiert und zuerst angezeigt
bb Interlaced-Video, unteres Halbbild codiert und zuerst angezeigt
tb Interlaced-Video, oben zuerst codiert, unten zuerst angezeigt
bt Interlaced-Video, unten zuerst codiert, oben zuerst angezeigt
überspringen_alpha ganze Zahl (Dekodierung, Video)
Auf 1 setzen, um die Verarbeitung von Alpha (Transparenz) zu deaktivieren. Das funktioniert wie grau Flagge in
Fahnen Option, die Chroma-Informationen anstelle von Alpha überspringt. Standard ist 0.
codec_whitelist Liste (Varianten des Eingangssignals:)
"," getrennt Liste der erlaubten Decoder. Standardmäßig sind alle erlaubt.
dump_separator Schnur (Varianten des Eingangssignals:)
Trennzeichen zum Trennen der Felder, die auf der Befehlszeile über den Stream gedruckt werden
Parameter. Um beispielsweise die Felder mit Zeilenumbrüchen und Einrückungen zu trennen:
ffprobe -dump_separator "
" -ich ~/videos/matrixbench_mpeg2.mpg
DECODER
Decoder sind konfigurierte Elemente in FFmpeg, die die Dekodierung von Multimedia-Streams ermöglichen.
Wenn Sie Ihren FFmpeg-Build konfigurieren, werden alle unterstützten nativen Decoder aktiviert durch
Ursprünglich. Decoder, die eine externe Bibliothek benötigen, müssen manuell über die
entsprechende "--enable-lib"-Option. Sie können alle verfügbaren Decoder mit dem
Konfigurieren Sie die Option "--list-decoders".
Sie können alle Decoder mit der Konfigurationsoption "--disable-decoders" deaktivieren und
selektiv einzelne Decoder aktivieren / deaktivieren mit den Optionen "--enable-decoder=DECODER" /
"--disable-decoder=DECODER".
Die Option "-decoders" des ff*-Tools zeigt die Liste der aktivierten Decoder an.
VIDEO DECODER
Es folgt eine Beschreibung einiger der derzeit verfügbaren Videodecoder.
Hevc
HEVC / H.265-Decoder.
Beachten Sie das skip_loop_filter Option hat nur auf Ebene "alle" Wirkung.
Rohvideo
Raw-Video-Decoder.
Dieser Decoder dekodiert Raw-Video-Streams.
Optionen
Top top_field_first
Geben Sie den angenommenen Feldtyp des Eingabevideos an.
-1 Es wird angenommen, dass das Video progressiv ist (Standard)
0 Bottom-Field-First wird angenommen
1 Top-Field-First wird angenommen
AUDIO DECODER
Es folgt eine Beschreibung einiger der derzeit verfügbaren Audio-Decoder.
ac3
AC-3 Audio-Decoder.
Dieser Decoder implementiert einen Teil von ATSC A/52:2010 und ETSI TS 102 366 sowie die
undokumentiertes RealAudio 3 (auch bekannt als dnet).
AC-3 Decoder Optionen
-drc_scale Wert
Skalierungsfaktor für den Dynamikbereich. Der Faktor, der auf Dynamikbereichswerte von AC-3 . anzuwenden ist
Strom. Dieser Faktor wird exponentiell angewendet. Es gibt 3 bemerkenswerte Skalierungsfaktoren
Bereiche:
drc_scale == 0
DRC deaktiviert. Erzeugt Full-Range-Audio.
0 < drc_scale <= 1
DRC aktiviert. Wendet einen Bruchteil des Stream-DRC-Werts an. Audiowiedergabe ist
zwischen Vollbereich und Vollkompression.
drc_scale > 1
DRC aktiviert. Wendet drc_scale asymmetrisch an. Laute Töne werden vollständig komprimiert.
Sanfte Klänge werden verstärkt.
flac
FLAC-Audio-Decoder.
Dieser Decoder zielt darauf ab, die vollständige FLAC-Spezifikation von Xiph zu implementieren.
FLAC Decoder Optionen
-use_buggy_lpc
Der lavc FLAC-Encoder, der verwendet wird, um fehlerhafte Streams mit hohen lpc-Werten zu erzeugen (wie die
Standardwert). Diese Option ermöglicht es, solche Streams korrekt zu dekodieren, indem
Verwenden der alten fehlerhaften Lpc-Logik von lavc zum Decodieren.
ffwavesynth
Interner Wellensynthetizer.
Dieser Decoder erzeugt Wellenmuster nach vordefinierten Sequenzen. Seine Verwendung ist rein
intern und das Format der akzeptierten Daten ist nicht öffentlich dokumentiert.
libcelt
libcelt-Decoder-Wrapper.
libcelt ermöglicht es libavcodec, den Audiocodec Xiph CELT mit extrem geringer Verzögerung zu decodieren. Erfordert
das Vorhandensein der libcelt-Header und der Bibliothek während der Konfiguration. Du musst
Konfigurieren Sie den Build explizit mit "--enable-libcelt".
libgsm
libgsm-Decoder-Wrapper.
libgsm ermöglicht es libavcodec, den GSM-Full-Rate-Audio-Codec zu decodieren. Erfordert die Anwesenheit von
die libgsm-Header und die Bibliothek während der Konfiguration. Sie müssen das explizit konfigurieren
mit "--enable-libgsm" bauen.
Dieser Decoder unterstützt sowohl die normale GSM- als auch die Microsoft-Variante.
libibc
libibc-Decoder-Wrapper.
libilbc ermöglicht es libavcodec, den Audio-Codec des Internet Low Bitrate Codec (iLBC) zu decodieren.
Erfordert das Vorhandensein der libibc-Header und der Bibliothek während der Konfiguration. Du musst
Konfigurieren Sie den Build explizit mit "--enable-libilbc".
Optionen
Die folgende Option wird vom libibc-Wrapper unterstützt.
zu steigern,
Aktivieren Sie die Verbesserung des decodierten Audios, wenn auf 1 gesetzt. Der Standardwert ist 0
(behindert).
libopencore-amrnb
libopencore-amrnb-Decoder-Wrapper.
libopencore-amrnb ermöglicht es libavcodec, das adaptive Multi-Rate-Narrowband-Audio zu decodieren
Codec. Die Verwendung erfordert das Vorhandensein der libopencore-amrnb-Header und der Bibliothek während
Aufbau. Sie müssen den Build explizit mit konfigurieren
"--enable-libopencore-amrnb".
Es gibt einen nativen FFmpeg-Decoder für AMR-NB, sodass Benutzer AMR-NB ohne diese decodieren können
Bibliothek.
libopencore-amrwb
libopencore-amrwb-Decoder-Wrapper.
libopencore-amrwb ermöglicht libavcodec die Dekodierung von Adaptive Multi-Rate Wideband Audio
Codec. Die Verwendung erfordert das Vorhandensein der libopencore-amrwb-Header und der Bibliothek während
Aufbau. Sie müssen den Build explizit mit konfigurieren
"--enable-libopencore-amrwb".
Ein nativer FFmpeg-Decoder für AMR-WB existiert, sodass Benutzer AMR-WB ohne diese decodieren können
Bibliothek.
Libopus
libopus-Decoder-Wrapper.
libopus ermöglicht es libavcodec, den Opus Interactive Audio Codec zu decodieren. Benötigt die
Vorhandensein der Libopus-Header und der Bibliothek während der Konfiguration. Sie müssen explizit
Konfigurieren Sie den Build mit "--enable-libopus".
Es existiert ein nativer FFmpeg-Decoder für Opus, sodass Benutzer Opus ohne diese Bibliothek decodieren können.
UNTERTITEL DECODER
DVBSub
Optionen
berechnen_clut
-1 Clut berechnen, wenn keine übereinstimmende CLUT im Stream vorhanden ist.
0 Berechnen Sie niemals CLUT
1 Berechnen Sie immer CLUT und überschreiben Sie die im Stream bereitgestellte.
dvb_substream
Wählt den DVB-Substream oder alle Substreams aus, wenn -1 der Standardwert ist.
DVDsub
Dieser Codec dekodiert die in DVDs verwendeten Bitmap-Untertitel; die gleichen Untertitel sind auch zu finden
in VobSub-Dateipaaren und in einigen Matroska-Dateien.
Optionen
Palette
Geben Sie die globale Palette an, die von den Bitmaps verwendet wird. Beim Speichern in VobSub ist die Palette
normalerweise in der Indexdatei angegeben; in Matroska wird die Palette im Codec gespeichert
Extra-Daten im gleichen Format wie in VobSub. Bei DVDs wird die Palette im IFO gespeichert
-Datei und ist daher beim Lesen aus gedumpten VOB-Dateien nicht verfügbar.
Das Format für diese Option ist eine Zeichenfolge mit 16 24-Bit-Hexadezimalzahlen
(ohne 0x-Präfix) durch Kommas getrennt, zum Beispiel "0d00ee, ee450d, 101010, eaeaea,
0ce60b, ec14ed, ebff0b, 0d617a, 7b7b7b, d1d1d1, 7b2a0e, 0d950c, 0f007b, cf0dec,
cfa80c, 7c127b".
ifo_palette
Geben Sie die IFO-Datei an, aus der die globale Palette abgerufen wird. (Experimental)
force_subs_only
Nur als erzwungen markierte Untertiteleinträge decodieren. Einige Titel haben erzwungene und nicht erzwungene
Untertitel im selben Track. Wenn Sie dieses Flag auf 1 setzen, wird nur das erzwungene
Untertitel. Der Standardwert ist 0.
libzvbi-Teletext
Libzvbi ermöglicht es libavcodec, DVB-Teletext-Seiten und DVB-Teletext-Untertitel zu decodieren.
Erfordert das Vorhandensein der libzvbi-Header und der Bibliothek während der Konfiguration. Du musst
Konfigurieren Sie den Build explizit mit "--enable-libzvbi".
Optionen
txt_seite
Liste der zu decodierenden Videotext-Seitennummern. Sie können den speziellen *-String verwenden, um alle zu finden
Seiten. Seiten, die nicht mit der angegebenen Liste übereinstimmen, werden gelöscht. Der Standardwert ist *.
txt_hack_top
Verwirft die oberste Videotextzeile. Der Standardwert ist 1.
txt_format
Gibt das Format der dekodierten Untertitel an. Der Videotext-Decoder kann
Um die Videotextseiten in Bitmaps oder in einfachen Text zu decodieren, sollten Sie "Bitmap" verwenden für
Videotextseiten, da bestimmte Grafiken und Farben nicht einfach ausgedrückt werden können
Text. Sie können "Text" für Videotext-basierte Untertitel verwenden, wenn Ihre Anwendung damit umgehen kann
einfache textbasierte Untertitel. Der Standardwert ist Bitmap.
txt_links
X-Offset der generierten Bitmaps, der Standardwert ist 0.
txt_top
Y-Offset der generierten Bitmaps, der Standardwert ist 0.
txt_chop_spaces
Schneidet führende und nachfolgende Leerzeichen ab und entfernt leere Zeilen aus dem generierten Text.
Diese Option ist nützlich für Videotext-basierte Untertitel, bei denen Leerstellen vorhanden sein können
am Anfang oder am Ende der Zeilen oder es können Leerzeilen zwischen den
Untertitelzeilen wegen doppelter Teletextzeichen. Der Standardwert ist 1.
txt_dauer
Stellt die Anzeigedauer der dekodierten Videotextseiten oder Untertitel in Millisekunden ein.
Der Standardwert ist 30000, was 30 Sekunden entspricht.
txt_transparent
Erzwingt transparenten Hintergrund der generierten Videotext-Bitmaps. Standardwert ist 0
was einen undurchsichtigen (schwarzen) Hintergrund bedeutet.
ENCODER
Encoder sind konfigurierte Elemente in FFmpeg, die die Kodierung von Multimedia-Streams ermöglichen.
Wenn Sie Ihren FFmpeg-Build konfigurieren, werden alle unterstützten nativen Encoder aktiviert durch
Ursprünglich. Encoder, die eine externe Bibliothek benötigen, müssen manuell über die
entsprechende "--enable-lib"-Option. Sie können alle verfügbaren Encoder über die
Konfigurieren Sie die Option "--list-encoders".
Sie können alle Encoder mit der Konfigurationsoption "--disable-encoders" deaktivieren und
selektiv einzelne Encoder aktivieren / deaktivieren mit den Optionen "--enable-encoder=ENCODER" /
"--disable-encoder=ENCODER".
Die Option "-encoders" des ff*-Tools zeigt die Liste der aktivierten Encoder an.
AUDIO ENCODER
Es folgt eine Beschreibung einiger der derzeit verfügbaren Audio-Encoder.
aac
Advanced Audio Coding (AAC)-Encoder.
Dieser Encoder ist ein experimenteller FFmpeg-nativer AAC-Encoder. Aktuell nur das Niedrige
Komplexitätsprofil (AAC-LC) wird unterstützt. Um diesen Encoder zu verwenden, müssen Sie einstellen streng zu erhalten
zu experimentell oder niedriger.
Da dieser Encoder experimentell ist, kann es von Zeit zu Zeit zu unerwartetem Verhalten kommen. Für ein
stabiler AAC-Encoder, siehe libvo-aacenc. Seien Sie jedoch gewarnt, dass es eine schlechtere Qualität hat
von einigen Benutzern gemeldet.
[VORLÄUFIGE VOLLAUTOMATISCHE TEXTÜBERSETZUNG - muss noch überarbeitet werden. Wir bitten um Ihr Verständnis.] libfdk_aac.
Optionen
b Bitrate in Bit/s einstellen. Wenn Sie dies einstellen, wird automatisch die konstante Bitrate (CBR) aktiviert.
Modus arbeiten können.
q Stellen Sie die Qualität für den Modus mit variabler Bitrate (VBR) ein. Diese Option ist nur gültig, wenn die
ffmpeg Kommandozeilen-Tool. Für Benutzer der Bibliotheksschnittstelle verwenden Sie globale_qualität.
stereo_modus
Legen Sie den Stereo-Kodierungsmodus fest. Mögliche Werte:
Auto
Wird automatisch vom Encoder ausgewählt.
ms_off
Deaktivieren Sie die mittlere/seitliche Kodierung. Dies ist die Standardeinstellung.
ms_force
Kodierung Mitte/Seite erzwingen.
aac_coder
Codierungsmethode für AAC-Encoder einstellen. Mögliche Werte:
faac
FAAC-inspirierte Methode.
Diese Methode ist eine vereinfachte Neuimplementierung der in FAAC verwendeten Methode, die
setzt Schwellenwerte proportional zu den Bandenergien und verringert dann alle
Schwellenwerte mit Quantisiererschritten, um die geeignete Quantisierung zu finden mit
Verzerrung unterhalb des Schwellenwerts Band für Band.
Die Qualität dieser Methode ist vergleichbar mit der Zweischleifen-Suchmethode
unten beschrieben, aber etwas besser und langsamer.
anmr
Trellis-basierte Lösung des durchschnittlichen Rauschen-zu-Masken-Verhältnisses (ANMR).
Dies hat die theoretisch beste Qualität aller Codierungsmethoden, aber auf Kosten
der langsamsten Geschwindigkeit.
Zweischleife
Suchmethode mit zwei Schleifen (TLS).
Diese Methode setzt zuerst Quantisierer in Abhängigkeit von Bandschwellen und versucht dann,
Finden Sie eine optimale Kombination, indem Sie einen bestimmten Wert von allen addieren oder subtrahieren
Quantisierer und passt einige einzelne Quantisierer ein wenig an.
Diese Methode erzeugt eine ähnliche Qualität wie die FAAC-Methode und ist die Standardeinstellung.
schnell
Konstante Quantisierungsmethode.
Diese Methode stellt einen konstanten Quantisierer für alle Bänder ein. Das ist das schnellste von allen
die Methoden, produziert aber die schlechteste Qualität.
ac3 und ac3_behoben
AC-3 Audio-Encoder.
Diese Encoder implementieren einen Teil von ATSC A/52:2010 und ETSI TS 102 366 sowie die
undokumentiertes RealAudio 3 (auch bekannt als dnet).
Die ac3 Encoder verwendet Gleitkomma-Mathematik, während die ac3_behoben Encoder verwendet nur Fest-
Punkt Integer math. Das heißt nicht, dass man immer schneller ist, nur der oder die
andere können für ein bestimmtes System besser geeignet sein. Der Gleitkomma-Encoder wird
produzieren im Allgemeinen eine bessere Audioqualität für eine bestimmte Bitrate. Die ac3_behoben Encoder ist nicht
der Standardcodec für eines der Ausgabeformate, daher muss er explizit mit . angegeben werden
die Option "-acodec ac3_fixed", um es zu verwenden.
AC-3 Metadaten
Die AC-3-Metadatenoptionen werden verwendet, um Parameter festzulegen, die das Audio beschreiben, aber in den meisten
Fälle wirken sich nicht auf die Audiocodierung selbst aus. Einige der Optionen wirken sich direkt auf oder
beeinflussen die Dekodierung und Wiedergabe des resultierenden Bitstreams, während andere nur für
Informationszwecken. Einige der Optionen fügen dem Ausgabestream Bits hinzu, die möglicherweise
andernfalls für Audiodaten verwendet werden und somit die Qualität der Ausgabe beeinträchtigen. Jene
wird entsprechend mit einem Hinweis in der untenstehenden Optionsliste gekennzeichnet.
Diese Parameter werden in mehreren öffentlich zugänglichen Dokumenten detailliert beschrieben.
*<http://www.atsc.org/cms/standards/a_52-2010.pdf>>
*<http://www.atsc.org/cms/standards/a_54a_with_corr_1.pdf>>
*<http://www.dolby.com/uploadedFiles/zz-_Shared_Assets/English_PDFs/Professional/18_Metadata.Guide.pdf>>
*<http://www.dolby.com/uploadedFiles/zz-_Shared_Assets/English_PDFs/Professional/46_DDEncodingGuidelines.pdf>>
Optionen zur Metadatensteuerung
-per_frame_metadata boolean
Metadaten pro Frame zulassen. Gibt an, ob der Encoder nach sich ändernden Metadaten suchen soll
für jeden Rahmen.
0 Die bei der Initialisierung eingestellten Metadatenwerte werden für jeden Frame im . verwendet
Strom. (Ursprünglich)
1 Metadatenwerte können vor der Codierung jedes Frames geändert werden.
Downmix-Stufen
-center_mixlev Grad des
Mitten-Mix-Pegel. Die Verstärkung, die der Decoder auf den Center-Kanal anwenden soll
beim Heruntermischen auf Stereo. Dieses Feld wird nur in den Bitstream geschrieben, wenn a
Center-Kanal vorhanden ist. Der Wert wird als Skalierungsfaktor angegeben. Es gibt 3 gültige
Werte:
0.707
-3dB Verstärkung anwenden
0.595
Anwenden von -4.5 dB Verstärkung (Standard)
0.500
-6dB Verstärkung anwenden
-surround_mixlev Grad des
Surround-Mix-Pegel. Die Verstärkung, die der Decoder auf den Surround anwenden soll
Kanal(e) beim Heruntermischen auf Stereo. Dieses Feld wird nur in den Bitstream geschrieben
wenn ein oder mehrere Surround-Kanäle vorhanden sind. Der Wert wird als Skala angegeben
Faktor. Es gibt 3 gültige Werte:
0.707
-3dB Verstärkung anwenden
0.500
Anwenden von -6 dB Verstärkung (Standard)
0.000
Stille Surround-Kanäle
Informationen zur Audioproduktion
Audioproduktionsinformationen sind optionale Informationen, die die Mischumgebung beschreiben.
Entweder keines oder beide Felder werden in den Bitstrom geschrieben.
-mixing_level Anzahl
Mischstufe. Gibt den Spitzenschalldruckpegel (SPL) in der Produktionsumgebung an
wenn der Mix gemastert wurde. Gültige Werte sind 80 bis 111 oder -1 für unbekannt oder nicht
angegeben. Der Standardwert ist -1, aber dieser Wert kann nicht verwendet werden, wenn die Audio
Produktionsinformationen werden in den Bitstrom geschrieben. Wenn also der "room_type"
option ist nicht der Standardwert, die Option "mixing_level" darf nicht -1 sein.
-Zimmertyp tippe
Zimmertyp. Beschreibt den Equalizer, der während der letzten Mixing-Session am
Studio oder auf der Synchronbühne. Ein großer Raum ist eine Synchronbühne mit der Industrie
Standard-X-Kurven-Entzerrung; ein kleiner Raum hat einen flachen Ausgleich. Dieses Feld wird
nicht in den Bitstream geschrieben werden, wenn sowohl die Option "mixing_level" als auch der "room_type"
Option haben die Standardwerte.
0
nicht angezeigt
Nicht angezeigt (Standard)
1
grosse
Großer Raum
2
klein
Kleiner Raum
Andere Metadaten-Optionen
-Urheberrechte © boolean
Copyright-Indikator. Gibt an, ob für dieses Audio ein Urheberrecht besteht.
0
WOW! Kein Urheberrecht vorhanden (Standard)
1
on Urheberrecht besteht
- Zifferblattnorm Wert
Dialog-Normalisierung. Gibt an, wie weit das durchschnittliche Dialogniveau des Programms ist
unterhalb des digitalen 100 %-Endwerts (0 dBFS). Dieser Parameter bestimmt eine Pegelverschiebung während
Audiowiedergabe, die die durchschnittliche Lautstärke des Dialogs auf einen voreingestellten Pegel setzt. Die
Ziel ist es, den Lautstärkepegel zwischen den Programmquellen anzupassen. Ein Wert von -31dB ergibt
keine Änderung des Lautstärkepegels relativ zur Quelllautstärke während der Audiowiedergabe.
Gültige Werte sind ganze Zahlen im Bereich -31 bis -1, wobei -31 der Standardwert ist.
-dsur_mode Modus
Dolby Surround-Modus. Gibt an, ob das Stereosignal Dolby Surround (Pro
Logik). Dieses Feld wird nur in den Bitstream geschrieben, wenn der Audiostream
Stereo. Wenn Sie diese Option verwenden, NICHT bedeutet, dass der Encoder tatsächlich Dolby Surround anwendet
Verarbeitung.
0
nicht angezeigt
Nicht angezeigt (Standard)
1
WOW! Nicht Dolby Surround-kodiert
2
on Dolby Surround-kodiert
-Original boolean
Ursprünglicher Bitstream-Indikator. Gibt an, ob dieses Audio vom Original stammt
Quelle und keine Kopie.
0
WOW! Nicht Originalquelle
1
on Originalquelle (Standard)
Verlängert Bitstream Info
Die erweiterten Bitstream-Optionen sind Teil der alternativen Bitstream-Syntax, wie in angegeben
Anhang D der Norm A/52:2010. Es ist in 2 Teile gruppiert. Wenn ein Parameter in a
group angegeben ist, werden alle Werte dieser Gruppe in den Bitstream geschrieben. Standard
Werte werden für diejenigen verwendet, die geschrieben, aber nicht angegeben wurden. Wenn das Mischen
geschrieben werden, verwendet der Decoder diese Werte anstelle der in der angegebenen Werte
"center_mixlev" und "surround_mixlev" Optionen, wenn es den Alternate Bit Stream unterstützt
Syntax.
Erweiterte Bitstream-Informationen - Teil 1
-dmix_mode Modus
Bevorzugter Stereo-Downmix-Modus. Ermöglicht dem Benutzer die Auswahl von Lt/Rt (Dolby Surround)
oder Lo/Ro (normales Stereo) als bevorzugten Stereo-Downmix-Modus.
0
nicht angezeigt
Nicht angezeigt (Standard)
1
ltr
Lt/Rt-Downmix bevorzugt
2
ihre
Lo/Ro-Downmix bevorzugt
-ltrt_cmixlev Grad des
Lt/Rt Center-Mix-Pegel. Die Verstärkung, die der Decoder auf die Mitte anwenden soll
Kanal beim Heruntermischen auf Stereo im Lt/Rt-Modus.
1.414
+3dB Verstärkung anwenden
1.189
+1.5dB Verstärkung anwenden
1.000
0dB Verstärkung anwenden
0.841
-1.5dB Verstärkung anwenden
0.707
-3.0dB Verstärkung anwenden
0.595
Anwenden von -4.5 dB Verstärkung (Standard)
0.500
-6.0dB Verstärkung anwenden
0.000
Stille Center-Kanal
-ltrt_surmixlev Grad des
Lt/Rt-Surround-Mix-Pegel. Die Verstärkung, die der Decoder auf den Surround anwenden soll
Kanal(s) beim Heruntermischen auf Stereo im Lt/Rt-Modus.
0.841
-1.5dB Verstärkung anwenden
0.707
-3.0dB Verstärkung anwenden
0.595
-4.5dB Verstärkung anwenden
0.500
Anwenden von -6.0 dB Verstärkung (Standard)
0.000
Stille Surround-Kanäle
-loro_cmixlev Grad des
Lo/Ro Center-Mix-Pegel. Die Verstärkung, die der Decoder auf die Mitte anwenden soll
Kanal beim Downmixen auf Stereo im Lo/Ro-Modus.
1.414
+3dB Verstärkung anwenden
1.189
+1.5dB Verstärkung anwenden
1.000
0dB Verstärkung anwenden
0.841
-1.5dB Verstärkung anwenden
0.707
-3.0dB Verstärkung anwenden
0.595
Anwenden von -4.5 dB Verstärkung (Standard)
0.500
-6.0dB Verstärkung anwenden
0.000
Stille Center-Kanal
-loro_surmixlev Grad des
Lo/Ro-Surround-Mix-Pegel. Die Verstärkung, die der Decoder auf den Surround anwenden soll
Kanal(s) beim Downmixen auf Stereo im Lo/Ro-Modus.
0.841
-1.5dB Verstärkung anwenden
0.707
-3.0dB Verstärkung anwenden
0.595
-4.5dB Verstärkung anwenden
0.500
Anwenden von -6.0 dB Verstärkung (Standard)
0.000
Stille Surround-Kanäle
Erweiterte Bitstream-Informationen - Teil 2
-dsurex_mode Modus
Dolby Surround EX-Modus. Zeigt an, ob der Stream Dolby Surround EX (7.1
Matrix zu 5.1). Wenn Sie diese Option verwenden, NICHT bedeutet, dass der Encoder tatsächlich zutrifft
Dolby Surround EX-Verarbeitung.
0
nicht angezeigt
Nicht angezeigt (Standard)
1
on Dolby Surround EX Aus
2
WOW! Dolby Surround EX Ein
-dheadphone_mode Modus
Dolby-Kopfhörermodus. Zeigt an, ob der Stream die Dolby Headphone-Kodierung verwendet
(Mehrkanal-Matrix auf 2.0 zur Verwendung mit Kopfhörern). Wenn Sie diese Option verwenden, NICHT
bedeutet, dass der Encoder die Dolby Headphone-Verarbeitung tatsächlich anwendet.
0
nicht angezeigt
Nicht angezeigt (Standard)
1
on Dolby-Kopfhörer aus
2
WOW! Dolby-Kopfhörer ein
-ad_conv_type tippe
A/D-Wandlertyp. Zeigt an, ob das Audio HDCD A/D passiert hat
Umwandlung.
0
Standard
Standard-A/D-Wandler (Standard)
1
hdd
HDCD A/D-Wandler
Andere AC-3 Codierung Optionen
-stereo_rematrixing boolean
Stereo-Rematrixing. Aktiviert/Deaktiviert die Verwendung von Rematrixing für den Stereoeingang. Das ist ein
optionale AC-3-Funktion, die die Qualität durch selektive Kodierung von links/rechts erhöht
Kanäle als Mitte/Seite. Diese Option ist standardmäßig aktiviert und wird dringend empfohlen
dass es außer zu Testzwecken aktiviert bleibt.
Nur Gleitkommazahlen AC-3 Codierung Optionen
Diese Optionen gelten nur für den Gleitkomma-Encoder und nicht für den
Festkomma-Encoder, da die entsprechenden Features nicht in Festkomma-
Punkt.
-channel_kopplung boolean
Aktiviert/Deaktiviert die Verwendung der Kanalkopplung, einer optionalen AC-3-Funktion, die
erhöht die Qualität durch die Kombination von Hochfrequenzinformationen aus mehreren Kanälen in
ein einzelner Kanal. Die Hochfrequenzinformationen pro Kanal werden mit weniger . gesendet
Genauigkeit sowohl im Frequenz- als auch im Zeitbereich. Dadurch können mehr Bits verwendet werden für
niedrigere Frequenzen, während genügend Informationen erhalten bleiben, um die Höhen zu rekonstruieren
Frequenzen. Diese Option ist standardmäßig für den Gleitkomma-Encoder aktiviert und
sollte generell aktiviert bleiben, außer zu Testzwecken oder zur Erhöhung
Codierungsgeschwindigkeit.
-1
Auto
Ausgewählt durch Encoder (Standard)
0
WOW! Kanalkopplung deaktivieren
1
on Kanalkopplung aktivieren
-cpl_start_band Anzahl
Kupplungsstartband. Legt das Startband der Kanalkopplung von 1 bis 15 fest. Wenn ein Wert
höher als die verwendete Bandbreite, wird auf 1 kleiner als das Kupplungsende reduziert
Band. Wenn Auto verwendet wird, wird das Startband vom Encoder anhand der
Bitrate, Abtastrate und Kanallayout. Diese Option hat keine Auswirkung, wenn Kanal
Kopplung ist deaktiviert.
-1
Auto
Ausgewählt durch Encoder (Standard)
flac
FLAC-Encoder (Free Lossless Audio Codec).
Optionen
Die folgenden Optionen werden vom flac-Encoder von FFmpeg unterstützt.
Kompressionslevel
Legt die Komprimierungsstufe fest, die Standardwerte für viele andere Optionen auswählt, wenn dies der Fall ist
nicht explizit eingestellt.
Rahmengröße
Legt die Größe der Frames in Samples pro Kanal fest.
lpc_coeff_precision
Legt die Genauigkeit des LPC-Koeffizienten fest, gültige Werte liegen zwischen 1 und 15, 15 ist die Standardeinstellung.
lpc_typ
Legt den LPC-Algorithmus der ersten Stufe fest
keine
LPC wird nicht verwendet
fixiert
feste LPC-Koeffizienten
Levinson
Cholesky
lpc_pässe
Anzahl der Durchgänge für die Cholesky-Faktorisierung während der LPC-Analyse
min_partition_order
Die minimale Partitionsreihenfolge
max_partition_order
Die maximale Partitionsreihenfolge
Prediction_order_method
Schätzung
2level
4level
8level
search
Bruteforce-Suche
Log
ch_mode
Kanalmodus
Auto
Der Modus wird automatisch für jedes Bild gewählt
Indep
Kanäle sind unabhängig codiert
linke Seite
rechte Seite
mitte_seite
genaue_reis_parameter
Wählt aus, ob die Reisparameter genau oder ungefähr berechnet werden. wenn auf 1 gesetzt dann
sie werden exakt gewählt, was den Code etwas verlangsamt und die Komprimierung verbessert
leicht.
multi_dim_quant
Multidimensionale Quantisierung. Wenn auf 1 gesetzt, wird ein LPC-Algorithmus der zweiten Stufe angewendet
nach der ersten Stufe, um die Koeffizienten zu verfeinern. Das ist ziemlich langsam und leicht
verbessert die Kompression.
libfaac
libfaac AAC (Advanced Audio Coding) Encoder-Wrapper.
Erfordert das Vorhandensein der libfaac-Header und der Bibliothek während der Konfiguration. Du musst
Konfigurieren Sie den Build explizit mit "--enable-libfaac --enable-nonfree".
Dieser Encoder gilt als qualitativ hochwertiger in Bezug auf die nativen
experimentell FFmpeg AAC Encoder.
Weitere Informationen finden Sie im libfaac-Projekt unterhttp://www.audiocoding.com/faac.html/>.
Optionen
Die folgenden freigegebenen FFmpeg-Codec-Optionen werden erkannt.
Die folgenden Optionen werden vom libfaac-Wrapper unterstützt. Die faac-Äquivalent der
Optionen sind in Klammern aufgeführt.
b (-b)
Stellen Sie die Bitrate in Bits/s für den ABR-Modus (Average Bit Rate) ein. Wenn die Bitrate nicht ist
explizit angegeben, wird er je nach . automatisch auf einen geeigneten Wert gesetzt
ausgewähltes Profil. faac Bitrate wird in Kilobit/s ausgedrückt.
Beachten Sie, dass libfaac kein CBR (Constant Bit Rate) unterstützt, sondern nur ABR (Average Bit .).
Rate).
Wenn der VBR-Modus aktiviert ist, wird diese Option ignoriert.
ar (-R)
Stellen Sie die Audio-Abtastrate (in Hz) ein.
ac (-c)
Stellen Sie die Anzahl der Audiokanäle ein.
Cutoff- (-C)
Cutoff-Frequenz einstellen. Wenn nicht angegeben (oder explizit auf 0 gesetzt), wird ein Wert verwendet
automatisch von der Bibliothek berechnet. Der Standardwert ist 0.
profile
Audioprofil einstellen.
Folgende Profile werden erkannt:
aac_main
Haupt-AAC (Haupt)
aac_low
AAC mit niedriger Komplexität (LC)
aac_ssr
Skalierbare Abtastrate (SSR)
aac_ltp
Langzeitprognose (LTP)
Wenn nicht angegeben, wird es auf gesetzt aac_low.
Fahnen +qskala
Stellen Sie den VBR-Modus (Variable Bitrate) mit konstanter Qualität ein.
globale_qualität
Stellen Sie die Qualität im VBR-Modus als ganze Zahl von Lambda-Einheiten ein.
Nur relevant, wenn der VBR-Modus mit "flags +qscale" aktiviert ist. Der Wert wird umgerechnet
in QP-Einheiten, indem es durch "FF_QP2LAMBDA" geteilt wird, und wird verwendet, um den verwendeten Qualitätswert einzustellen
von libfaac. Ein sinnvoller Bereich für den Optionswert in QP-Einheiten ist [10-500], der
höher der Wert, desto höher die Qualität.
q (-q)
Aktivieren Sie den VBR-Modus, wenn er auf einen nicht negativen Wert eingestellt ist, und stellen Sie den konstanten Qualitätswert als a . ein
doppelter Gleitkommawert in QP-Einheiten.
Der Wert legt den von libfaac verwendeten Qualitätswert fest. Ein vernünftiger Bereich für die Option
Wert [10-500] ist, je höher der Wert, desto höher die Qualität.
Diese Option ist nur gültig, wenn die ffmpeg Kommandozeilen-Tool. Für Bibliotheksschnittstelle
Benutzer, verwenden globale_qualität.
Beispiele
· Verwenden ffmpeg So konvertieren Sie eine Audiodatei in ABR 128 kbps AAC in einem M4A (MP4)-Container:
ffmpeg -i input.wav -codec:a libfaac -b:a 128k -output.m4a
· Verwenden ffmpeg So konvertieren Sie eine Audiodatei mit dem LTP AAC-Profil in VBR AAC:
ffmpeg -i input.wav -c:a libfaac -profile:a aac_ltp -q:a 100 output.m4a
libfdk_aac
libfdk-aac AAC-Encoder-Wrapper (Advanced Audio Coding).
Die Bibliothek libfdk-aac basiert auf dem Fraunhofer FDK AAC-Code aus dem Android-Projekt.
Erfordert das Vorhandensein der libfdk-aac-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit "--enable-libfdk-aac" zu konfigurieren. Die Bibliothek ist auch
inkompatibel mit GPL. Wenn Sie die Verwendung von GPL zulassen, sollten Sie mit konfigurieren
"--enable-gpl --enable-nonfree --enable-libfdk-aac".
Dieser Encoder wird in Bezug auf beides als qualitativ hochwertiger angesehen nativen
experimentell FFmpeg AAC Encoder und libfaac.
VBR-Kodierung, aktiviert durch die vbr or Fahnen +qskala Optionen, ist experimentell und nur
arbeitet mit einigen Kombinationen von Parametern.
Unterstützung für das Kodieren von 7.1-Audio ist nur mit libfdk-aac 0.1.3 oder höher verfügbar.
Weitere Informationen finden Sie im fdk-aac-Projekt unter
<http://sourceforge.net/p/opencore-amr/fdk-aac/>.
Optionen
Die folgenden Optionen werden den freigegebenen FFmpeg-Codec-Optionen zugeordnet.
b Bitrate in Bit/s einstellen. Wenn die Bitrate nicht explizit angegeben ist, ist sie
automatisch je nach ausgewähltem Profil auf einen geeigneten Wert eingestellt.
Falls der VBR-Modus aktiviert ist, wird die Option ignoriert.
ar Stellen Sie die Audio-Abtastrate (in Hz) ein.
Kanäle
Stellen Sie die Anzahl der Audiokanäle ein.
Fahnen +qskala
Aktivieren Sie den VBR-Modus (Variable Bitrate) mit fester Qualität. Beachten Sie, dass VBR implizit ist
aktiviert, wenn die vbr Wert ist positiv.
Cutoff-
Cutoff-Frequenz einstellen. Wenn nicht angegeben (oder explizit auf 0 gesetzt), wird ein Wert verwendet
automatisch von der Bibliothek berechnet. Der Standardwert ist 0.
profile
Audioprofil einstellen.
Folgende Profile werden erkannt:
aac_low
AAC mit niedriger Komplexität (LC)
aac_he
Hocheffiziente AAC (HE-AAC)
aac_he_v2
Hocheffiziente AAC-Version 2 (HE-AACv2)
aac_ld
AAC mit geringer Verzögerung (LD)
aac_feld
Verbesserte AAC mit geringer Verzögerung (ELD)
Wenn nicht angegeben, wird es auf gesetzt aac_low.
Die folgenden sind private Optionen des Encoders libfdk_aac.
Nachbrenner
Nachbrennerfunktion aktivieren, wenn auf 1 gesetzt, deaktiviert, wenn auf 0 gesetzt. Dies verbessert die
Qualität, sondern auch die erforderliche Rechenleistung.
Der Standardwert ist 1.
feld_sbr
SBR (Spectral Band Replication) für ELD aktivieren, wenn auf 1 gesetzt, deaktiviert, wenn auf 0 gesetzt.
Der Standardwert ist 0.
Signalisierung
Stellen Sie den SBR/PS-Signalisierungsstil ein.
Es kann einen der folgenden Werte annehmen:
Standard
Wählen Sie die Signalisierung implizit (standardmäßig explizit hierarchisch, implizit, wenn global)
Kopfzeile ist deaktiviert)
implizit
implizite abwärtskompatible Signalisierung
explizit_sbr
explizites SBR, implizite PS-Signalisierung
explizit_hierarchisch
explizite hierarchische Signalisierung
Standardwert ist Standard.
lat
Gekapselte LATM/LOAS-Daten ausgeben, wenn auf 1 gesetzt, deaktiviert, wenn auf 0 gesetzt.
Der Standardwert ist 0.
header_periode
Legen Sie StreamMuxConfig und PCE-Wiederholungsperiode (in Frames) für das Senden im Band fest
Konfigurationspuffer innerhalb der LATM/LOAS-Transportschicht.
Muss eine nicht negative ganze 16-Bit-Ganzzahl sein.
Der Standardwert ist 0.
vbr Stellen Sie den VBR-Modus von 1 bis 5 ein. 1 ist die niedrigste Qualität (obwohl immer noch ziemlich gut) und 5 ist
höchste Qualität. Ein Wert von 0 deaktiviert VBR und CBR (konstante Bitrate) ist
aktiviert.
Derzeit nur die aac_low Profil unterstützt die VBR-Codierung.
Die VBR-Modi 1-5 entsprechen ungefähr den folgenden durchschnittlichen Bitraten:
1 32 kbps/Kanal
2 40 kbps/Kanal
3 48-56 kbps/Kanal
4 64 kbps/Kanal
5 ca. 80-96 kbps/Kanal
Der Standardwert ist 0.
Beispiele
· Verwenden ffmpeg So konvertieren Sie eine Audiodatei in VBR AAC in einem M4A (MP4)-Container:
ffmpeg -i input.wav -codec:a libfdk_aac -vbr 3 output.m4a
· Verwenden ffmpeg um eine Audiodatei in CBR 64k kbps AAC zu konvertieren, mit dem High-Efficiency AAC
Profil:
ffmpeg -i input.wav -c:a libfdk_aac -profile:a aac_he -b:a 64k Output.m4a
libmp3lame
LAME (Lame ist kein MP3-Encoder) MP3-Encoder-Wrapper.
Erfordert das Vorhandensein der libmp3lame-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit "--enable-libmp3lame" zu konfigurieren.
Weitere Informationen finden Sie auch in den libshine für einen Festkomma-MP3-Encoder, allerdings mit geringerer Qualität.
Optionen
Die folgenden Optionen werden vom libmp3lame-Wrapper unterstützt. Die paralytisch-Äquivalent der
Optionen sind in Klammern aufgeführt.
b (-b)
Stellen Sie die Bitrate in Bits/s für CBR oder ABR ein. LAME "Bitrate" wird ausgedrückt in
Kilobit/s.
q (-V)
Stellen Sie eine konstante Qualitätseinstellung für VBR ein. Diese Option ist nur gültig, wenn die ffmpeg
Kommandozeilen-Tool. Für Benutzer der Bibliotheksschnittstelle verwenden Sie globale_qualität.
Kompressionslevel (-q)
Algorithmusqualität einstellen. Gültige Argumente sind ganze Zahlen im Bereich von 0-9 mit der Bedeutung 0
höchste Qualität, aber am langsamsten, und 9 bedeutet am schnellsten bei der schlechtesten Qualität.
Reservoir
Aktivieren Sie die Verwendung des Bit-Reservoirs, wenn es auf 1 gesetzt ist. Der Standardwert ist 1. LAME hat dies aktiviert
standardmäßig, kann aber durch Verwendung überschrieben werden --nores .
gemeinsame_Stereo (-m j)
Aktivieren Sie den Encoder, um (Frame für Frame) entweder L/R Stereo oder Mid/Side zu verwenden
Stereo. Der Standardwert ist 1.
April (--abr)
Aktivieren Sie den Encoder, um ABR zu verwenden, wenn er auf 1 gesetzt ist paralytisch --abr legt die Zielbitrate fest,
während diese Option nur FFmpeg anweist, ABR zu verwenden, verlässt es sich immer noch auf b Bitrate einzustellen.
libopencore-amrnb
OpenCORE Adaptiver Multi-Rate Schmalband-Encoder.
Erfordert das Vorhandensein der libopencore-amrnb-Header und der Bibliothek während der Konfiguration.
Sie müssen den Build explizit mit "--enable-libopencore-amrnb . konfigurieren
--enable-version3".
Dies ist ein Nur-Mono-Encoder. Offiziell unterstützt es nur eine Abtastrate von 8000 Hz, aber Sie können
überschreiben Sie es, indem Sie einstellen streng zu inoffiziell oder niedriger.
Optionen
b Stellen Sie die Bitrate in Bits pro Sekunde ein. Nur die folgenden Bitraten werden sonst unterstützt
libavcodec rundet auf die nächste gültige Bitrate.
4750
5150
5900
6700
7400
7950
10200
12200
dtx Erlaube diskontinuierliche Übertragung (Erzeuge Komfortgeräusche), wenn auf 1 gesetzt. Die Standardeinstellung
Wert ist 0 (deaktiviert).
libshine
Shine Fixed-Point MP3-Encoder-Wrapper.
Shine ist ein Festkomma-MP3-Encoder. Es hat eine weitaus bessere Leistung auf Plattformen ohne
eine FPU, zB armel CPUs, und einige Telefone und Tablets. Da es jedoch gezielter auf
Leistung als Qualität, es ist nicht mit LAME und anderen produktionstauglichen Encodern vergleichbar
qualitätsmäßig. Laut der Homepage des Projekts ist dieser Encoder möglicherweise nicht frei von
Fehler, da der Code vor langer Zeit geschrieben wurde und das Projekt für mindestens 5 . tot war
Jahre.
Dieser Encoder unterstützt nur Stereo- und Mono-Eingänge. Dies ist auch nur CBR.
Das ursprüngliche Projekt (zuletzt aktualisiert Anfang 2007) ist bei
<http://sourceforge.net/projects/libshine-fxp/>. Wir unterstützen nur den aktualisierten Fork von der
Savonet/Liquidseifen-Projekt beihttps://github.com/savonet/shine>.
Erfordert das Vorhandensein der libshine-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit "--enable-libshine" zu konfigurieren.
[VORLÄUFIGE VOLLAUTOMATISCHE TEXTÜBERSETZUNG - muss noch überarbeitet werden. Wir bitten um Ihr Verständnis.] libmp3lame.
Optionen
Die folgenden Optionen werden vom libshine-Wrapper unterstützt. Die Glanz-Äquivalent von
die Optionen sind in Klammern aufgeführt.
b (-b)
Stellen Sie die Bitrate in Bits/s für CBR ein. Glanz -b Option wird ausgedrückt in
Kilobit/s.
libtwolame
TwoLAME MP2-Encoder-Wrapper.
Erfordert das Vorhandensein der libtwolame-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit "--enable-libtwolame" zu konfigurieren.
Optionen
Die folgenden Optionen werden vom libtwolame-Wrapper unterstützt. Die Twolame-Äquivalent
Optionen folgen den FFmpeg-Optionen und stehen in Klammern.
b (-b)
Stellen Sie die Bitrate in Bits/s für CBR ein. Twolame b Option wird in Kilobit/s ausgedrückt.
Der Standardwert ist 128k.
q (-V)
Stellen Sie die Qualität für experimentelle VBR-Unterstützung ein. Der maximale Wertebereich reicht von -50 bis 50,
Der nützliche Bereich liegt zwischen -10 und 10. Je höher der Wert, desto besser die Qualität. Dies
Option ist nur gültig, wenn die ffmpeg Kommandozeilen-Tool. Für Benutzer der Bibliotheksschnittstelle:
- globale_qualität.
Modus (--Modus)
Stellen Sie den Modus des resultierenden Audios ein. Mögliche Werte:
Auto
Wählen Sie den Modus automatisch basierend auf der Eingabe. Dies ist die Standardeinstellung.
Stereo
Stereo
gemeinsame_Stereo
Gemeinsame Stereoanlage
Doppelkanal
Dual-Channel-
Mono
Mono
Psymodel (--Psych-Modus)
Legen Sie das psychoakustische Modell fest, das bei der Codierung verwendet werden soll. Das Argument muss eine ganze Zahl zwischen sein
-1 und 4, inklusive. Je höher der Wert, desto besser die Qualität. Der Standardwert
ist 3.
Energiewerte (--Energie)
Aktivieren Sie Energiestufenerweiterungen, wenn auf 1 gesetzt. Der Standardwert ist 0 (deaktiviert).
error_protection (--beschützen)
Aktivieren Sie den CRC-Fehlerschutz, wenn auf 1 gesetzt. Der Standardwert ist 0 (deaktiviert).
Urheberrecht (--Urheberrechte ©)
Setzen Sie das MPEG-Audio-Copyright-Flag, wenn es auf 1 gesetzt ist. Der Standardwert ist 0 (deaktiviert).
Original (--Original)
Setzen Sie das MPEG-Audio-Original-Flag, wenn es auf 1 gesetzt ist. Der Standardwert ist 0 (deaktiviert).
libvo-aacenc
VisualOn AAC-Encoder.
Erfordert das Vorhandensein der libvo-aacenc-Header und der Bibliothek während der Konfiguration. Du
müssen den Build explizit mit "--enable-libvo-aacenc --enable-version3" konfigurieren.
Dieser Encoder gilt als schlechter als der nativen experimentell FFmpeg AAC Encoder,
nach mehreren Quellen.
Optionen
Der VisualOn AAC-Encoder unterstützt nur die Kodierung von AAC-LC und bis zu 2 Kanälen. Es ist auch
Nur CBR.
b Bitrate in Bit/s einstellen.
libvo-amrwbenc
VisualOn Adaptiver Multi-Rate-Breitband-Encoder.
Erfordert das Vorhandensein der libvo-amrwbenc-Header und der Bibliothek während der Konfiguration. Du
müssen den Build explizit mit "--enable-libvo-amrwbenc --enable-version3" konfigurieren.
Dies ist ein Nur-Mono-Encoder. Offiziell unterstützt es nur eine Abtastrate von 16000 Hz, aber Sie können
überschreiben Sie es, indem Sie einstellen streng zu inoffiziell oder niedriger.
Optionen
b Bitrate in Bit/s einstellen. Es werden nur die folgenden Bitraten unterstützt, ansonsten libavcodec
wird auf die nächste gültige Bitrate gerundet.
6600
8850
12650
14250
15850
18250
19850
23050
23850
dtx Erlaube diskontinuierliche Übertragung (Erzeuge Komfortgeräusche), wenn auf 1 gesetzt. Die Standardeinstellung
Wert ist 0 (deaktiviert).
Libopus
libopus Opus Interactive Audio Codec Encoder Wrapper.
Erfordert das Vorhandensein der libopus-Header und der Bibliothek während der Konfiguration. Du musst
den Build explizit mit "--enable-libopus" konfigurieren.
Option Mapping
Die meisten Libopus-Optionen sind nach dem opusenc Dienstprogramm von opus-tools. Folgende
ist ein Options-Mapping-Diagramm, das Optionen beschreibt, die vom libopus-Wrapper unterstützt werden, und deren
opusenc-äquivalent in Klammern.
b (Bitrate)
Stellen Sie die Bitrate in Bits/s ein. FFmpegs b Option wird in Bits/s ausgedrückt, während opusenc's
Bitrate in Kilobit/s.
vbr (vbr, hart-cbr, und Lebenslauf)
Stellen Sie den VBR-Modus ein. Das FFmpeg vbr Option hat die folgenden gültigen Argumente, mit deren
opusenc äquivalente Optionen in Klammern:
WOW! (hart-cbr)
Verwenden Sie eine Kodierung mit konstanter Bitrate.
on (vbr)
Verwenden Sie die Codierung mit variabler Bitrate (Standard).
eingeschränkt (Lebenslauf)
Verwenden Sie die Codierung mit eingeschränkter variabler Bitrate.
Kompressionslevel (Layout-Datei)
Legen Sie die Komplexität des Kodierungsalgorithmus fest. Gültige Optionen sind Ganzzahlen im Bereich von 0-10. 0
gibt die schnellsten Codierungen, aber niedrigere Qualität, während 10 die höchste Qualität liefert, aber
langsamste Codierung. Der Standardwert ist 10.
Rahmen_Dauer (Rahmengröße)
Legen Sie die maximale Framegröße oder die Dauer eines Frames in Millisekunden fest. Das Argument muss sein
genau wie folgt: 2.5, 5, 10, 20, 40, 60. Kleinere Rahmengrößen erreichen niedrigere
Latenz, aber weniger Qualität bei einer bestimmten Bitrate. Größen über 20 ms sind nur
interessant bei relativ niedrigen Bitraten. Der Standardwert ist 20 ms.
Paketverlust (erwarten-Verlust)
Legen Sie den Prozentsatz des erwarteten Paketverlusts fest. Der Standardwert ist 0.
Anwendung (N / A)
Stellen Sie den beabsichtigten Anwendungstyp ein. Gültige Optionen sind unten aufgeführt:
voip
Bevorzugen Sie eine verbesserte Sprachverständlichkeit.
Audio-
Bevorzugen Sie die Treue zur Eingabe (Standardeinstellung).
geringe Verzögerung
Beschränken Sie sich nur auf die niedrigsten Verzögerungsmodi.
Cutoff- (N / A)
Cutoff-Bandbreite in Hz einstellen. Das Argument muss genau eines der folgenden sein: 4000,
6000, 8000, 12000 oder 20000, entsprechend Schmalband, Mittelband, Breitband, Super
Breitband bzw. Vollband. Der Standardwert ist 0 (Abschaltung deaktiviert).
libvorbis
libvorbis-Encoder-Wrapper.
Erfordert das Vorhandensein der libvorbisenc-Header und der Bibliothek während der Konfiguration. Du
müssen den Build explizit mit "--enable-libvorbis" konfigurieren.
Optionen
Die folgenden Optionen werden vom libvorbis-Wrapper unterstützt. Die oggenc-Äquivalent der
Optionen sind in Klammern aufgeführt.
Um eine genauere und ausführlichere Dokumentation der libvorbis-Optionen zu erhalten, konsultieren Sie die
libvorbisencs und oggenc's Dokumentationen. Sehenhttp://xiph.org/vorbis/>,
<http://wiki.xiph.org/Vorbis-tools>, und oggenc(1).
b (-b)
Stellen Sie die Bitrate in Bits/s für ABR ein. oggenc -b wird in Kilobit/s ausgedrückt.
q (-q)
Stellen Sie eine konstante Qualitätseinstellung für VBR ein. Der Wert sollte eine Gleitkommazahl im Bereich sein
von -1.0 bis 10.0. Je höher der Wert, desto besser die Qualität. Der Standardwert ist
3.0.
Diese Option ist nur gültig, wenn die ffmpeg Kommandozeilen-Tool. Für Bibliotheksschnittstelle
Benutzer, verwenden globale_qualität.
Cutoff- (--advanced-encode-option Tiefpassfrequenz=N)
Cutoff-Bandbreite in Hz einstellen, ein Wert von 0 deaktiviert Cutoff. oggenc's verwandte Option ist
in kHz ausgedrückt. Der Standardwert ist 0 (Abschaltung deaktiviert).
Minrate (-m)
Stellen Sie die minimale Bitrate in Bits/s ein. oggenc -m wird in Kilobit/s ausgedrückt.
Maximale Rate (-M)
Stellen Sie die maximale Bitrate in Bits/s ein. oggenc -M wird in Kilobit/s ausgedrückt. Dies
wirkt sich nur auf den ABR-Modus aus.
ich blockiere (--advanced-encode-option Impulse_noisetune=N)
Einstellen des Grundrauschens für Impulsblöcke. Der Wert ist eine Gleitkommazahl von -15.0 bis
0.0. Ein negativer Bias weist den Encoder an, besonders auf die Knusprigkeit zu achten
von Transienten im codierten Audio. Der Kompromiss für ein besseres Einschwingverhalten ist a
höhere Bitrate.
libwavpack
Ein Wrapper, der die WavPack-Codierung über libwavpack bereitstellt.
Derzeit wird nur der verlustfreie Modus mit 32-Bit-Integer-Samples unterstützt.
Erfordert das Vorhandensein der libwavpack-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit "--enable-libwavpack" zu konfigurieren.
Beachten Sie, dass ein libavcodec-nativer Encoder für den WavPack-Codec existiert, damit Benutzer codieren können
Audios mit diesem Codec, ohne diesen Encoder zu verwenden. Sehen wavpackenc.
Optionen
wavpaket Die entsprechenden Optionen des Befehlszeilen-Dienstprogramms sind in Klammern aufgeführt, falls vorhanden.
Rahmengröße (--Block Größe)
Standard ist 32768.
Kompressionslevel
Kompromiss zwischen Geschwindigkeit und Komprimierung einstellen. Annehmbare Argumente sind unten aufgeführt:
0 (-f)
Schneller Modus.
1 Normale (Standard-) Einstellungen.
2 (-h)
Qualität.
3 (-hh)
Sehr hohe Qualität.
4 8 (-hh -xEXTRAPROZ)
Das gleiche wie 3, aber mit aktivierter zusätzlicher Verarbeitung.
4 ist die gleiche wie -x2 und 8 ist die gleiche wie -x6.
wavpaket
Verlustfreier WavPack-Audio-Encoder.
Dies ist ein libavcodec-nativer WavPack-Encoder. Es gibt auch einen Encoder basierend auf libwavpack,
aber es gibt praktisch keinen Grund, diesen Encoder zu verwenden.
[VORLÄUFIGE VOLLAUTOMATISCHE TEXTÜBERSETZUNG - muss noch überarbeitet werden. Wir bitten um Ihr Verständnis.] libwavpack.
Optionen
Die entsprechenden Optionen für wavpaket Befehlszeilen-Dienstprogramm sind in Klammern aufgeführt.
Gemeinsame Optionen
Die folgenden gemeinsamen Optionen sind für diesen Encoder wirksam. Dazu nur besondere Hinweise
der jeweilige Encoder wird hier dokumentiert. Zur allgemeinen Bedeutung der Optionen siehe
Codec Optionen Kapitel.
Rahmengröße (--Block Größe)
Bei diesem Encoder liegt der Bereich für diese Option zwischen 128 und 131072. Standard ist
automatisch basierend auf Abtastrate und Kanalanzahl entschieden.
Die vollständige Formel zur Berechnung des Ausfalls finden Sie unter libavcodec/wavpackenc.c.
Kompressionslevel (-f, -h, -hh, und -x)
Die Syntax dieser Option ist konsistent mit libwavpack'S.
Private Optionen
gemeinsame_Stereo (-j)
Legen Sie fest, ob gemeinsames Stereo aktiviert werden soll. Gültige Werte sind:
on (1)
Mitten-/Seiten-Audiocodierung erzwingen.
WOW! (0)
Audiocodierung links/rechts erzwingen.
Auto
Lassen Sie den Encoder automatisch entscheiden.
optimieren_mono
Legen Sie fest, ob die Optimierung für Mono aktiviert werden soll. Diese Option ist nur für Nicht-
Monostreams. Verfügbare Werte:
on freigegeben
WOW! behindert
VIDEO ENCODER
Es folgt eine Beschreibung einiger der derzeit verfügbaren Video-Encoder.
jpeg2000
Der native JPEG-2000-Encoder ist standardmäßig verlustbehaftet, die Option "-q:v" kann verwendet werden, um die
Kodierungsqualität. Mit "-pred 1" kann eine verlustfreie Kodierung ausgewählt werden.
Optionen
Format
Kann entweder auf "j2k" oder "jp2" (Standard) eingestellt werden, wodurch es möglich ist, nicht-
rgb pix_fmts.
.
Optionen
iterative_dia_size
dia Größe für die iterative Bewegungsschätzung
libtheora
libtheora Theora-Encoder-Wrapper.
Erfordert das Vorhandensein der libtheora-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit "--enable-libtheora" zu konfigurieren.
Weitere Informationen zum libtheora-Projekt finden Sie unterhttp://www.theora.org/>.
Optionen
Die folgenden globalen Optionen werden internen libtheora-Optionen zugeordnet, die sich auf die
Qualität und die Bitrate des codierten Streams.
b Stellen Sie die Videobitrate in Bit/s für den CBR-Modus (konstante Bitrate) ein. Falls VBR
(Variable Bitrate) Modus ist aktiviert diese Option wird ignoriert.
Fahnen
Wird verwendet, um die Codierung im Konstantqualitätsmodus (VBR) durch die qskala Flagge und zu
Aktivieren Sie die Modi "pass1" und "pass2".
g Legen Sie die GOP-Größe fest.
globale_qualität
Legen Sie die globale Qualität als Ganzzahl in Lambda-Einheiten fest.
Nur relevant, wenn der VBR-Modus mit "flags +qscale" aktiviert ist. Der Wert wird umgerechnet in
QP-Einheiten, indem sie durch "FF_QP2LAMBDA" geteilt werden, im Bereich von [0 - 10] abgeschnitten, und dann
mit 6.3 multipliziert, um einen Wert im nativen libtheora-Bereich [0-63] zu erhalten. Ein höherer Wert
entspricht einer höheren Qualität.
q Aktivieren Sie den VBR-Modus, wenn er auf einen nicht negativen Wert eingestellt ist, und stellen Sie den konstanten Qualitätswert als a . ein
doppelter Gleitkommawert in QP-Einheiten.
Der Wert wird im Bereich von [0-10] abgeschnitten und dann mit 6.3 multipliziert, um einen Wert in zu erhalten
der native libtheora-Bereich [0-63].
Diese Option ist nur gültig, wenn die ffmpeg Kommandozeilen-Tool. Für Bibliotheksschnittstelle
Benutzer, verwenden globale_qualität.
Beispiele
· Stellen Sie die Kodierung mit maximaler konstanter Qualität (VBR) ein mit ffmpeg:
ffmpeg -i EINGABE -codec:v libtheora -q:v 10 AUSGABE.ogg
· Verwenden ffmpeg So konvertieren Sie einen CBR 1000 kbps Theora-Videostream:
ffmpeg -i EINGABE -codec:v libtheora -b:v 1000k AUSGABE.ogg
libvpx
VP8/VP9-Format wird von libvpx unterstützt.
Erfordert das Vorhandensein der libvpx-Header und der Bibliothek während der Konfiguration. Du musst
Konfigurieren Sie den Build explizit mit "--enable-libvpx".
Optionen
Die folgenden Optionen werden vom libvpx-Wrapper unterstützt. Die vpxenc-äquivalente Optionen
oder Werte sind in Klammern aufgeführt, um die Migration zu erleichtern.
Um die doppelte Dokumentation zu reduzieren, nur die privaten Optionen und einige andere
besondere Aufmerksamkeit erfordern, sind hier dokumentiert. Zur Dokumentation des Undokumentierten
generische Optionen, siehe Codec Optionen Kapitel.
Um weitere Dokumentation der libvpx-Optionen zu erhalten, rufen Sie den Befehl auf ffmpeg -h
Encoder=libvpx, ffmpeg -h Encoder=libvpx-vp9 or vpxenc --help. Weitere Informationen sind
in der libvpx-API-Dokumentation verfügbar.
b (Ziel-Bitrate)
Bitrate in Bit/s einstellen. Beachten Sie, dass FFmpegs b Option wird in Bits/s ausgedrückt, während
vpxenc's Ziel-Bitrate ist in Kilobit/s angegeben.
g (kf-max-Abst)
keyint_min (kf-Min-Abst)
qmin (min-q)
qmax (max-q)
Puffergröße (buf-sz, buf-optimal-sz)
Legen Sie die Puffergröße der Ratensteuerung fest (in Bit). Notiz vpxenc's Optionen sind in . angegeben
Millisekunden wandelt der libvpx-Wrapper diesen Wert wie folgt um: "buf-sz = bufsize *
1000 / Bitrate", "buf-optimal-sz = bufsize * 1000 / Bitrate * 5 / 6".
rc_init_occupancy (buf-Anfangsgr)
Legen Sie die Anzahl der Bits fest, die in den RC-Puffer geladen werden sollen, bevor die Decodierung beginnt.
Note vpxenc's Option wird in Millisekunden angegeben, der libvpx-Wrapper konvertiert dies
Wert wie folgt: "rc_init_occupancy * 1000 / Bitrate".
unterschreitung-pct
Stellen Sie den Prozentsatz der Datenratenunterschreitung (min) der Zielbitrate ein.
Überschwinger-pct
Stellen Sie den Prozentsatz der Datenratenüberschreitung (max.) der Zielbitrate ein.
überspringen_threshold (Drop-Frame)
qkomp (Bias-pct)
Maximale Rate (maxsection-pct)
Legen Sie die maximale GOP-Bitrate in Bits/s fest. Notiz vpxenc's Option wird als Prozentsatz von . angegeben
die Zielbitrate, wandelt der libvpx-Wrapper diesen Wert wie folgt um: "(maxrate * 100
/ Bitrate)".
Minrate (minsection-pct)
Stellen Sie die minimale GOP-Bitrate in Bits/s ein. Notiz vpxenc's Option wird als Prozentsatz von . angegeben
die Zielbitrate, wandelt der libvpx-Wrapper diesen Wert wie folgt um: "(minrate * 100
/ Bitrate)".
Minze, Maximale Rate, b end-use=cbr
"(minrate == maxrate == bitrate)".
crf (Endverwendung=cq, cq-Ebene)
Qualität, Frist (Frist)
beste
Verwenden Sie die Frist für die beste Qualität. Diese Option ist schlecht benannt und ziemlich langsam
vermieden, da dies eine schlechtere als eine gute Ausgabequalität liefern kann.
gut
Verwenden Sie eine Frist von guter Qualität. Dies ist ein guter Kompromiss zwischen Geschwindigkeit und Qualität, wenn
verwendet mit dem CPU-benutzt .
Echtzeit
Verwenden Sie Echtzeit-Qualitätsfristen.
Geschwindigkeit, CPU-benutzt (CPU-benutzt)
Stellen Sie den Modifikator für das Qualitäts-/Geschwindigkeitsverhältnis ein. Höhere Werte beschleunigen die Kodierung auf Kosten von
Qualität.
nr (Geräuschempfindlichkeit)
statisch-dresch
Legen Sie für Blöcke einen Änderungsschwellenwert fest, unterhalb dessen sie vom Encoder übersprungen werden.
Scheiben (Token-Teile)
Beachten Sie, dass FFmpegs Scheiben Option gibt die Gesamtzahl der Partitionen an, während vpxenc's
Token-Teile wird als "log2(partitions)" angegeben.
Max-Intra-Rate
Legen Sie die maximale I-Frame-Bitrate als Prozentsatz der Zielbitrate fest. Ein Wert von 0 bedeutet
unbegrenzt.
force_key_frames
"VPX_EFLAG_FORCE_KF"
Wechseln Referenz Rahmen bezogene
Auto-Alt-Ref
Aktivieren Sie die Verwendung alternativer Referenzbilder (nur 2 Durchgänge).
arnr-max-frames
Legen Sie die maximale Bildanzahl der Altref-Rauschunterdrückung fest.
Arnr-Typ
Altref-Rauschunterdrückungsfiltertyp einstellen: rückwärts, vorwärts, zentriert.
Arnr-Stärke
Legen Sie die Filterstärke der altref-Rauschunterdrückung fest.
rc-Vorausschau, Lag-in-Frames (Lag-in-Frames)
Stellen Sie die Anzahl der Frames ein, um nach Frametyp und Ratecontrol zu suchen.
fehlerresistent
Aktivieren Sie die Fehlerausfallsicherheitsfunktionen.
VP9-spezifisch Optionen
verlustfrei
Aktivieren Sie den verlustfreien Modus.
Kachel-Säulen
Legen Sie die Anzahl der zu verwendenden Kachelspalten fest. Beachten Sie, dass dies als "log2(tile_columns)" angegeben wird. Zum
Beispiel: 8 Kachelspalten würden angefordert, indem die Kachel-Säulen Option zu
3.
Fliesenreihen
Legen Sie die Anzahl der zu verwendenden Kachelreihen fest. Beachten Sie, dass dies als "log2(tile_rows)" angegeben wird. Zum
Beispiel: 4 Kachelreihen würden angefordert, indem die Fliesenreihen Möglichkeit zu 2.
rahmenparallel
Aktivieren Sie die Funktionen zur parallelen Decodierbarkeit von Frames.
aq-Modus
Einstellen des adaptiven Quantisierungsmodus (0: aus (Standard), 1: Varianz 2: Komplexität, 3:
zyklische Aktualisierung).
Farbraum Farbraum
Legen Sie den Eingabefarbraum fest. Der VP9-Bitstream unterstützt die folgende Signalisierung
Farbräume:
RGB sRGB
bt709 bt709
nicht spezifiziert unbekannt
bt470bg bt601
smpte170m smpte170
smpte240m smpte240
bt2020_ncl bt2020
Weitere Informationen zu libvpx finden Sie unter:http://www.webmproject.org/>
libwebp
libwebp WebP Image-Encoder-Wrapper
libwebp ist Googles offizieller Encoder für WebP-Bilder. Es kann entweder verlustbehaftet oder kodiert werden
verlustfreier Modus. Verlustbehaftete Bilder sind im Wesentlichen ein Wrapper um einen VP8-Frame. Verlustfreie Bilder
sind ein separater Codec, der von Google entwickelt wurde.
Pixel Format
Derzeit unterstützt libwebp aufgrund von Einschränkungen nur YUV420 für verlustbehaftet und RGB für verlustfrei
des Formats und libwebp. Alpha wird für beide Modi unterstützt. Wegen API
Einschränkungen, wenn RGB bei verlustbehafteter Kodierung oder YUV bei Kodierung übergeben wird
verlustfrei, das Pixelformat wird automatisch mit Funktionen von libwebp konvertiert.
Dies ist nicht ideal und dient nur der Bequemlichkeit.
Optionen
-verlustfrei boolean
Aktiviert/Deaktiviert die Verwendung des verlustfreien Modus. Standard ist 0.
-Kompressionsstufe ganze Zahl
Für verlustbehaftete ist dies ein Kompromiss zwischen Qualität und Geschwindigkeit. Höhere Werte ergeben eine bessere Qualität für a
gegebene Größe auf Kosten einer erhöhten Codierungszeit. Für verlustfrei ist dies eine Größe/Geschwindigkeit
Abtausch. Höhere Werte ergeben eine kleinere Größe auf Kosten einer erhöhten Codierungszeit. Mehr
insbesondere steuert es die Anzahl der zusätzlichen Algorithmen und Komprimierungstools, die verwendet werden,
und variiert die Kombination dieser Werkzeuge. Dies entspricht dem Methode Option in libwebp.
Der gültige Bereich ist 0 bis 6. Der Standardwert ist 4.
-qscale schweben
Bei verlustbehafteter Kodierung steuert dies die Bildqualität, 0 bis 100. Bei verlustfreier Kodierung dies
kontrolliert den Aufwand und die Zeit, die für das Komprimieren aufgewendet werden. Der Standardwert ist 75. Hinweis
dass für die Verwendung über libavcodec diese Option aufgerufen wird globale_qualität und muss sein
multipliziert mit FF_QP2LAMBDA.
-voreingestellt tippe
Konfigurationsvoreinstellung. Dies führt einige automatische Einstellungen basierend auf der allgemeinen Art von
das Bild.
keine
Verwenden Sie keine Voreinstellung.
Standard
Verwenden Sie die Encoder-Standardeinstellung.
ein Bild
Digitales Bild, wie Portrait, Innenaufnahme
für Ihre privaten Foto
Außenaufnahme mit natürlichem Licht
Zeichnung
Hand- oder Strichzeichnung mit kontrastreichen Details
icon
Kleine bunte Bilder
Text
Textartig
libx264, libx264rgb
x264 H.264/MPEG-4 AVC-Encoder-Wrapper.
Dieser Encoder erfordert das Vorhandensein der libx264-Header und der Bibliothek während
Aufbau. Sie müssen den Build explizit mit "--enable-libx264" konfigurieren.
libx264 unterstützt eine beeindruckende Anzahl von Funktionen, darunter 8x8 und 4x4 Adaptive Spatial
Transformation, adaptive B-Frame-Platzierung, CAVLC/CABAC-Entropiecodierung, Interlacing (MBAFF),
verlustfreier Modus, Psy-Optimierungen zur Detailerhaltung (adaptive Quantisierung, Psy-RD, Psy-
Gitter).
Viele libx264-Encoder-Optionen sind den globalen FFmpeg-Codec-Optionen zugeordnet, während sie einzigartig sind
Encoderoptionen werden über private Optionen bereitgestellt. Zusätzlich die x264 opt und
x264-Parameter private options erlaubt es, eine Liste von key=value-Tupeln zu übergeben, die von akzeptiert werden
die libx264-Funktion "x264_param_parse".
Die x264-Projektwebsite ist unterhttp://www.videolan.org/developers/x264.html>.
Der libx264rgb-Encoder ist der gleiche wie libx264, außer dass er gepackte RGB-Pixelformate akzeptiert
als Eingabe anstelle von YUV.
Unterstützte Pixel Formate
x264 unterstützt 8- bis 10-Bit-Farbräume. Die genaue Bittiefe wird bei x264 gesteuert
Zeit konfigurieren. FFmpeg unterstützt nur eine Bittiefe in einem bestimmten Build. In anderen
Worten, es ist nicht möglich, ein FFmpeg mit mehreren Versionen von x264 mit zu erstellen
verschiedene Bittiefen.
Optionen
Die folgenden Optionen werden vom libx264-Wrapper unterstützt. Die x264-äquivalente Optionen oder
Werte sind in Klammern aufgeführt, um die Migration zu erleichtern.
Um die doppelte Dokumentation zu reduzieren, nur die privaten Optionen und einige andere
besondere Aufmerksamkeit erfordern, sind hier dokumentiert. Zur Dokumentation des Undokumentierten
generische Optionen, siehe Codec Optionen Kapitel.
Um eine genauere und umfangreichere Dokumentation der libx264-Optionen zu erhalten, rufen Sie die
Befehl x264 --volle-Hilfe oder konsultieren Sie die libx264-Dokumentation.
b (Bitrate)
Bitrate in Bit/s einstellen. Beachten Sie, dass FFmpegs b Option wird in Bits/s ausgedrückt, während
x264's Bitrate ist in Kilobit/s angegeben.
bf (bframes)
g (keyint)
qmin (qpm)
Minimale Quantisierungsskala.
qmax (qpmax)
Maximale Quantisierungsskala.
qdiff (qpschritt)
Maximaler Unterschied zwischen Quantisierungsskalen.
qblur (qblur)
Unschärfe der Quantisierungskurve
qkomp (qkomp)
Kompressionsfaktor der Quantizer-Kurve
Ref (ref)
Anzahl der Referenzbilder, die jedes P-Bild verwenden kann. Das Sortiment ist von 0 16 .
sc_threshold (Szenenschnitt)
Legt den Schwellenwert für die Szenenwechselerkennung fest.
Gitter (Gitter)
Führt Trellis-Quantisierung durch, um die Effizienz zu steigern. Standardmäßig aktiviert.
nr (nr)
me_range (merange)
Maximaler Bereich der Bewegungssuche in Pixeln.
me_method (me)
Bewegungsschätzungsmethode einstellen. Mögliche Werte in absteigender Reihenfolge der Geschwindigkeit:
Tag (Tag)
epz (Tag)
Diamantsuche mit Radius 1 (am schnellsten). epz ist ein Alias für Tag.
hex (hex)
Sechseckige Suche mit Radius 2.
ähm (ähm)
Ungleichmäßige Suche mit mehreren Sechsecken.
esa (esa)
Erschöpfende Suche.
tesa (tesa)
Hadamard erschöpfende Suche (am langsamsten).
unterq (abonniere mich)
Verfahren zur Schätzung der Subpixel-Bewegung.
b_strategie (b-anpassen)
Adaptiver Entscheidungsalgorithmus für die B-Frame-Platzierung. Nur beim ersten Durchgang verwenden.
keyint_min (min-keyint)
Minimale GOP-Größe.
Coder
Entropie-Encoder einstellen. Mögliche Werte:
ac CABAC aktivieren.
vlc Aktivieren Sie CAVLC und deaktivieren Sie CABAC. Es erzeugt den gleichen Effekt wie x264's --no-cabac
.
CMP Stellen Sie den Vergleichsalgorithmus zur vollständigen Pixelbewegungsschätzung ein. Mögliche Werte:
Chroma
Aktivieren Sie Chroma in der Bewegungsschätzung.
traurig Ignorieren Sie Chroma bei der Bewegungsschätzung. Es erzeugt den gleichen Effekt wie x264's
--no-chroma-me .
Themen (Themen)
Anzahl der Codierungsthreads.
Gewindetyp
Stellen Sie die Multithreading-Technik ein. Mögliche Werte:
Scheibe
Slice-basiertes Multithreading. Es erzeugt den gleichen Effekt wie x264's
--Schnittfäden .
Rahmen
Framebasiertes Multithreading.
Fahnen
Codierungsflags setzen. Es kann verwendet werden, um geschlossene GOP zu deaktivieren und offene GOP zu aktivieren, indem
auf "-cgop" setzen. Das Ergebnis ist ähnlich dem Verhalten von x264's --open-gop
.
rc_init_occupancy (vbv-init)
voreingestellten (voreingestellten)
Legen Sie die Kodierungsvorgabe fest.
Melodie (Melodie)
Stellen Sie die Abstimmung der Codierungsparameter ein.
profile (profile)
Legen Sie Profilbeschränkungen fest.
schnellersterpass
Schnelle Einstellungen beim Codieren des ersten Durchgangs aktivieren, wenn auf 1 gesetzt. Wenn auf 0 gesetzt, hat es
der gleiche Effekt von x264's --langsamer erster Durchgang .
crf (crf)
Stellen Sie die Qualität für den konstanten Qualitätsmodus ein.
crf_max (crf-max)
Verhindert im CRF-Modus, dass VBV die Qualität über diesen Punkt hinaus verringert.
qp (qp)
Stellen Sie den Parameter für die konstante Quantisierungsrate-Steuerungsmethode ein.
aq-Modus (aq-Modus)
Stellen Sie die AQ-Methode ein. Mögliche Werte:
keine (0)
Behindert.
Unterschied (1)
Varianz AQ (Komplexitätsmaske).
Autovarianz (2)
Auto-Varianz-AQ (experimentell).
aq-Stärke (aq-Stärke)
Stellen Sie die AQ-Stärke ein, reduzieren Sie Blockierungen und Unschärfen in flachen und strukturierten Bereichen.
psy Psychovisuelle Optimierungen verwenden, wenn auf 1 gesetzt. Wenn auf 0 gesetzt, hat es den gleichen Effekt wie
x264's --nein-psy .
psy-rd (psy-rd)
Stärke der psychovisuellen Optimierung einstellen, in psy-rd:Psy-Spalier Format.
rc-Lookahead (rc-Lookahead)
Stellen Sie die Anzahl der Frames ein, um nach Frametyp und Ratecontrol zu suchen.
Gewichtb
Aktivieren Sie die gewichtete Vorhersage für B-Frames, wenn sie auf 1 gesetzt ist. Wenn sie auf 0 gesetzt ist, hat sie dasselbe
Wirkung als x264's --no-weightb .
Gewichtp (Gewichtp)
Legen Sie die gewichtete Vorhersagemethode für P-Frames fest. Mögliche Werte:
keine (0)
Deaktiviert
einfach (1)
Nur gewichtete Referenzen aktivieren
smart (2)
Aktivieren Sie sowohl gewichtete Referenzen als auch Duplikate
sim (sim)
Aktivieren Sie die Berechnung und das Drucken von SSIM-Statistiken nach der Codierung.
Intra-Refresh (Intra-Refresh)
Aktivieren Sie die Verwendung von Periodic Intra Refresh anstelle von IDR-Frames, wenn auf 1 gesetzt.
Avcintra-Klasse (Klasse)
Konfigurieren Sie den Encoder, um AVC-Intra zu generieren. Gültige Werte sind 50,100 und 200
Bluray-Kompatibilität (Bluray-Kompatibilität)
Konfigurieren Sie den Encoder so, dass er mit dem Bluray-Standard kompatibel ist. Es ist eine Abkürzung
zum Setzen von "bluray-compat=1 force-cfr=1".
b-Vorspannung (b-Vorspannung)
Stellen Sie den Einfluss ein, wie oft B-Frames verwendet werden.
b-Pyramide (b-Pyramide)
Legen Sie die Methode fest, um einige B-Frames als Referenzen zu behalten. Mögliche Werte:
keine (keine)
Behindert.
streng (streng)
Streng hierarchische Pyramide.
normal (normal)
Nicht streng (nicht Blu-ray-kompatibel).
gemischt-refs
Aktivieren Sie die Verwendung einer Referenz pro Partition, im Gegensatz zu einer Referenz pro
Makroblock, wenn auf 1 gesetzt. Wenn auf 0 gesetzt, hat es die gleiche Wirkung wie x264's
--no-mixed-refs .
8x8dkt
Aktivieren Sie die adaptive räumliche Transformation (High-Profile 8x8-Transformation), wenn auf 1 gesetzt. Wenn eingestellt
auf 0 hat es den gleichen Effekt wie x264's --no-8x8dct .
schnell-pskip
Aktivieren Sie die frühe SKIP-Erkennung bei P-Frames, wenn sie auf 1 gesetzt ist. Wenn sie auf 0 gesetzt ist, hat sie dasselbe
Wirkung als x264's --no-fast-pskip .
aud (aud)
Aktivieren Sie die Verwendung von Trennzeichen für Zugriffseinheiten, wenn auf 1 gesetzt.
mbbaum
Aktivieren Sie die Verwendung der Makroblock-Tree-Ratensteuerung, wenn sie auf 1 gesetzt ist. Wenn sie auf 0 gesetzt ist, hat sie die gleiche
Wirkung als x264's --no-mbtree .
deblockieren (deblockieren)
Schleifenfilterparameter einstellen, in Alpha:Beta Form.
cplxblur (cplxblur)
Fluktuationsreduzierung in QP einstellen (vor Kurvenkompression).
Partituren (Partituren)
Legen Sie Partitionen fest, die als durch Kommas getrennte Liste betrachtet werden sollen. Mögliche Werte in der Liste:
p8x8
8x8 P-Rahmen-Trennwand.
p4x4
4x4 P-Rahmen-Trennwand.
b8x8
4x4 B-Rahmen-Trennwand.
i8x8
8x8 I-Frame-Partition.
i4x4
4x4 I-Frame-Partition. (Aktivieren p4x4 erfordert p8x8 aktiviert werden. Aktivieren i8x8
erfordert adaptive räumliche Transformation (8x8dkt Option) aktiviert werden.)
keine (keine)
Berücksichtigen Sie keine Partitionen.
alle (alle)
Betrachten Sie jede Partition.
direkt-pred (direkt)
Stellen Sie den direkten AMV-Vorhersagemodus ein. Mögliche Werte:
keine (keine)
Deaktivieren Sie die AMV-Vorhersage.
räumliche (räumliche)
Aktivieren Sie die räumliche Vorhersage.
temporäre (temporäre)
Aktivieren Sie die zeitliche Vorhersage.
Auto (Auto)
Automatisch entschieden.
Slice-Max-Größe (Slice-Max-Größe)
Legen Sie die Begrenzung der Größe jedes Slice in Byte fest. Wenn nicht angegeben, aber RTP-Nutzlast
Größe (ps) angegeben ist, das verwendet wird.
Statistik (Statistik)
Legen Sie den Dateinamen für Multi-Pass-Statistiken fest.
nal-hrd (nal-hrd)
Stellen Sie die HRD-Informationen des Signals ein (erfordert vbv-buffsize eingestellt werden). Mögliche Werte:
keine (keine)
Deaktivieren Sie die HRD-Informationssignalisierung.
vbr (vbr)
Variable Bitrate.
cbr (cbr)
Konstante Bitrate (nicht zulässig im MP4-Container).
x264 opt (N / A)
Stellen Sie eine beliebige x264-Option ein, siehe x264 --volle Hilfe für eine Liste.
Argument ist eine Liste von Haupt=Wert Paare durch ":" getrennt. In Filter und psy-rd Optionen
die ":" selbst als Trennzeichen verwenden, verwenden Sie stattdessen ",". Sie akzeptieren es auch, da
vor langer Zeit, aber dies wird aus irgendeinem Grund undokumentiert.
Um beispielsweise libx264-Kodierungsoptionen mit . anzugeben ffmpeg:
ffmpeg -i foo.mpg -vcodec libx264 -x264opts keyint=123:min-keyint=20 -an out.mkv
x264-Parameter (N / A)
Überschreiben Sie die x264-Konfiguration mit einer :-getrennten Liste von Schlüssel=Wert-Parametern.
Diese Option ist funktional identisch mit der x264 opt, wird aber für . dupliziert
Kompatibilität mit der Libav-Gabel.
Um beispielsweise libx264-Kodierungsoptionen mit . anzugeben ffmpeg:
ffmpeg -i INPUT -c:v libx264 -x264-params level=30:bframes=0:weightp=0:\
cabac=0:ref=1:vbv-maxrate=768:vbv-bufsize=2000:analyse=all:me=umh:\
no-fast-pskip=1:subq=6:8x8dct=0:trellis=0 OUTPUT
Kodierungs-FF-Voreinstellungen für allgemeine Verwendungen werden bereitgestellt, damit sie mit dem allgemeinen verwendet werden können
Voreinstellungen-System (z. B. das Bestehen der vor Möglichkeit).
libx265
x265 H.265/HEVC-Encoder-Wrapper.
Dieser Encoder erfordert das Vorhandensein der libx265-Header und der Bibliothek während
Aufbau. Sie müssen den Build explizit mit konfigurieren --enable-libx265.
Optionen
voreingestellten
Stellen Sie die x265-Voreinstellung ein.
Melodie
Stellen Sie den x265-Abstimmungsparameter ein.
x265-Parameter
Legen Sie x265-Optionen mithilfe einer Liste von fest Haupt=Wert Paare durch ":" getrennt. Sehen x265 --help
für eine Liste mit Optionen.
Um beispielsweise libx265-Kodierungsoptionen mit . anzugeben -x265-Parameter:
ffmpeg -i Eingabe -c:v libx265 -x265-params crf=26:psy-rd=1 Ausgabe.mp4
libxvid
Xvid MPEG-4 Part 2-Encoder-Wrapper.
Dieser Encoder erfordert das Vorhandensein der libxvidcore-Header und der Bibliothek während
Aufbau. Sie müssen den Build explizit mit "--enable-libxvid . konfigurieren
--enable-gpl".
Der native "mpeg4"-Encoder unterstützt das MPEG-4 Part 2-Format, sodass Benutzer dieses Format codieren können
ohne diese Bibliothek formatieren.
Optionen
Die folgenden Optionen werden vom libxvid-Wrapper unterstützt. Einige der folgenden Optionen
aufgeführt, aber nicht dokumentiert, und entsprechen freigegebenen Codec-Optionen. Sehen Codec
Optionen Kapitel für ihre Dokumentation. Die anderen gemeinsamen Optionen, die nicht aufgeführt sind
haben keine Auswirkungen auf den libxvid-Encoder.
b
g
qmin
qmax
mpeg_quant
Themen
bf
b_qfaktor
b_qoffset
Fahnen
Legen Sie spezifische Codierungsflags fest. Mögliche Werte:
mv4 Verwenden Sie vier Bewegungsvektoren pro Makroblock.
aic Aktivieren Sie eine hochwertige AC-Vorhersage.
grau
Nur Graustufen kodieren.
gmc Aktivieren Sie die Verwendung der globalen Bewegungskompensation (GMC).
qpel
Aktivieren Sie die Viertelpixel-Bewegungskompensation.
cgop
Geschlossene GOP aktivieren.
global_header
Platzieren Sie globale Header in Extradaten anstelle jedes Keyframes.
Gitter
me_method
Bewegungsschätzungsmethode einstellen. Mögliche Werte in absteigender Reihenfolge der Geschwindigkeit und
aufsteigende Qualität:
Null
Keine Bewegungsschätzung verwenden (Standard).
Phods
x1
Log Aktiviert die erweiterte Diamantzonensuche für 16x16-Blöcke und Halbpixel-Verfeinerung
für 16x16 Blöcke. x1 und Log sind Pseudonyme für Phods.
epz
Aktivieren Sie alle oben beschriebenen Dinge sowie die erweiterte Diamantzonensuche für
8x8-Blöcke, Halbpixel-Verfeinerung für 8x8-Blöcke und Bewegungsschätzung auf Chroma
Flugzeuge.
voller
Aktivieren Sie alle oben beschriebenen Dinge sowie erweiterte 16x16- und 8x8-Blöcke
Suche.
mbd Legen Sie den Makroblock-Entscheidungsalgorithmus fest. Mögliche Werte in aufsteigender Qualität:
einfach
Verwenden Sie den Algorithmus der Makroblock-Vergleichsfunktion (Standard).
Bits
Aktivieren Sie die ratenverzerrungsbasierte Halbpixel- und Viertelpixel-Verfeinerung für 16x16
Blöcke
rd Aktivieren Sie alle oben beschriebenen Dinge, plus ratenverzerrungsbasierte halbe Pixel
und Viertelpixel-Verfeinerung für 8x8-Blöcke und ratenverzerrungsbasierte Suche
mit quadratischem Muster.
lumi_aq
Aktivieren Sie die adaptive Quantisierung der Lumi-Maskierung, wenn sie auf 1 gesetzt ist. Die Standardeinstellung ist 0 (deaktiviert).
Abweichung_aq
Aktivieren Sie die adaptive Varianzquantisierung, wenn sie auf 1 gesetzt ist. Die Standardeinstellung ist 0 (deaktiviert).
In Kombination mit lumi_aq, wird die resultierende Qualität nicht besser sein als die
zwei einzeln angegeben. Mit anderen Worten, die resultierende Qualität wird schlechter sein
einer der beiden Effekte.
sim
Stellen Sie die Anzeigemethode für die strukturelle Ähnlichkeit (SSIM) ein. Mögliche Werte:
WOW! Deaktivieren Sie die Anzeige von SSIM-Informationen.
avg Ausgabe des durchschnittlichen SSIM am Ende der Codierung auf stdout. Das Format der Anzeige der
durchschnittliche SSIM ist:
Durchschnittliche SSIM: %f
Für Benutzer, die mit C nicht vertraut sind, bedeutet %f eine Gleitkommazahl oder eine Dezimalzahl (zB
0.939232).
Rahmen
Geben Sie sowohl SSIM-Daten pro Frame während der Codierung als auch durchschnittliche SSIM am Ende von . aus
codierung auf stdout. Das Format der Informationen pro Frame ist:
SSIM: Durchschnitt: %1.3f Min: %1.3f Max: %1.3f
Für Benutzer, die mit C nicht vertraut sind, bedeutet %1.3f eine auf 3 . gerundete Gleitkommazahl
Ziffern nach dem Punkt (zB 0.932).
ssim_acc
Stellen Sie die SSIM-Genauigkeit ein. Gültige Optionen sind ganze Zahlen im Bereich von 0-4, während 0 ergibt
das genaueste Ergebnis und 4 berechnet am schnellsten.
mpeg2
MPEG-2-Video-Encoder.
Optionen
seq_disp_ext ganze Zahl
Gibt an, ob der Encoder eine sequence_display_extension in den Ausgang schreiben soll.
-1
Auto
Entscheiden Sie automatisch, ob Sie es schreiben möchten oder nicht (dies ist die Standardeinstellung), indem Sie überprüfen, ob die
die zu schreibenden Daten unterscheiden sich von den Standard- oder nicht spezifizierten Werten.
0
niemals
Schreiben Sie es nie.
1
immer
Schreiben Sie es immer.
png
PNG-Bildcodierer.
Privat Optionen
dpi ganze Zahl
Stellen Sie die physikalische Dichte der Pixel in Punkten pro Zoll ein, standardmäßig nicht eingestellt
dpm ganze Zahl
Physikalische Pixeldichte in Punkten pro Meter einstellen, standardmäßig nicht eingestellt
ProRes
Apple ProRes-Encoder.
FFmpeg enthält 2 ProRes-Encoder, den prores-aw- und den prores-ks-Encoder. Der verwendete Encoder
kann mit der Option "-vcodec" ausgewählt werden.
Privat Optionen für prores-ks
profile ganze Zahl
Wählen Sie das zu codierende ProRes-Profil aus
Stellvertreter
lt
Standard
hq
4444
quant_mat ganze Zahl
Quantisierungsmatrix auswählen.
Auto
Standard
Stellvertreter
lt
Standard
hq
Wenn auf Auto, wird die zum Profil passende Matrix ausgewählt. Wenn nicht eingestellt, wird die
Matrix für höchste Qualität, Standard, wird abgeholt.
bits_per_mb ganze Zahl
Wie viele Bits sind für die Codierung eines Makroblocks zuzuweisen. Unterschiedliche Profile verwenden zwischen 200
und 2400 Bits pro Makroblock beträgt das Maximum 8000.
mbs_per_slice ganze Zahl
Anzahl von Makroblöcken in jedem Slice (1-8); der Standardwert (8) sollte gut sein in
fast alle Situationen.
Verkäufer Schnur
Überschreiben Sie die 4-Byte-Anbieter-ID. Eine benutzerdefinierte Anbieter-ID wie apl0 würde den Stream beanspruchen
wurde vom Apple-Encoder produziert.
alpha_bits ganze Zahl
Geben Sie die Anzahl der Bits für die Alphakomponente an. Mögliche Werte sind 0, 8 und 16. Benutzen 0
um die Alpha-Ebenen-Codierung zu deaktivieren.
Schnelligkeit Überlegungen
Im Standard-Betriebsmodus muss der Encoder Frame-Beschränkungen berücksichtigen (dh nicht
Rahmen mit einer größeren Größe als angefordert produzieren), während das Ausgabebild immer noch so gut ist
wie möglich. Ein Rahmen mit vielen kleinen Details ist schwerer zu komprimieren und die
Encoder würde mehr Zeit damit verbringen, nach geeigneten Quantisierern für jedes Slice zu suchen.
Höher einstellen bits_per_mb Limit wird die Geschwindigkeit verbessern.
Für die schnellste Codierungsgeschwindigkeit stellen Sie die qskala Parameter (4 ist der empfohlene Wert) und
Legen Sie keine Größenbeschränkung fest.
libkvazaar
Kvazaar H.265/HEVC-Encoder.
Erfordert das Vorhandensein der libkvazaar-Header und der Bibliothek während der Konfiguration. Du brauchst
um den Build explizit mit zu konfigurieren --enable-libkvazaar.
Optionen
b Stellen Sie die Zielvideobitrate in Bit/s ein und aktivieren Sie die Ratensteuerung.
Themen
Legen Sie die Anzahl der Codierungsthreads fest.
kvazaar-params
Stellen Sie kvazaar-Parameter als Liste von . ein Name=Wert durch Kommas (,) getrennte Paare. Sehen
kvazaar-Dokumentation für eine Liste der Optionen.
UNTERTITEL ENCODER
DVDsub
Dieser Codec codiert das Bitmap-Untertitelformat, das in DVDs verwendet wird. Typischerweise sind sie
in VOBSUB-Dateipaaren (*.idx + *.sub) gespeichert und können auch in Matroska-Dateien verwendet werden.
Optionen
Even_rows_fix
Wenn auf 1 gesetzt, aktivieren Sie eine Problemumgehung, die die Anzahl der Pixelzeilen insgesamt gleichmäßig macht
Untertitel. Dies behebt ein Problem mit einigen Spielern, die die untere Reihe abschneiden, wenn die
Nummer ist ungerade. Die Problemumgehung fügt bei Bedarf einfach eine vollständig transparente Zeile hinzu. Die
Der Overhead ist gering, typischerweise ein Byte pro Untertitel im Durchschnitt.
Diese Problemumgehung ist standardmäßig deaktiviert.
BITSTREAM FILTER
Wenn Sie Ihren FFmpeg-Build konfigurieren, werden alle unterstützten Bitstream-Filter aktiviert durch
Ursprünglich. Sie können alle verfügbaren mit der Konfigurationsoption "--list-bsfs" auflisten.
Sie können alle Bitstream-Filter mit der Konfigurationsoption "--disable-bsfs" deaktivieren und
Aktivieren Sie selektiv jeden Bitstream-Filter mit der Option "--enable-bsf=BSF", oder Sie können
deaktivieren Sie einen bestimmten Bitstream-Filter mit der Option "--disable-bsf=BSF".
Die Option "-bsfs" der ff*-Tools zeigt die Liste aller unterstützten Bitstreams an
Filter, die in Ihrem Build enthalten sind.
Die ff*-Tools haben eine -bsf-Option, die pro Stream angewendet wird, wobei eine durch Kommas getrennte Liste von
filter, deren Parameter dem Filternamen nach einem '=' folgen.
ffmpeg -i EINGANG -c:v kopieren -bsf:v filter1[=opt1=str1/opt2=str2][,filter2] AUSGANG
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Bitstream-Filter mit ihren
Parameter, falls vorhanden.
aac_adtstoasc
Konvertieren Sie MPEG-2/4 AAC ADTS in einen MPEG-4 Audio Specific Configuration Bitstream-Filter.
Dieser Filter erstellt eine MPEG-4 AudioSpecificConfig aus einem MPEG-2/4 ADTS-Header und entfernt
den ADTS-Header.
Dies ist zum Beispiel erforderlich, wenn Sie einen AAC-Stream von einem rohen ADTS AAC-Container in einen AAC-Container kopieren
FLV oder eine MOV/MP4-Datei.
chomp
Entfernen Sie Null-Padding am Ende eines Pakets.
dump_extra
Fügen Sie zusätzliche Daten am Anfang der gefilterten Pakete hinzu.
Das zusätzliche Argument gibt an, welche Pakete gefiltert werden sollen. Es akzeptiert die
Werte:
a füge Extradaten zu allen Schlüsselpaketen hinzu, aber nur, wenn local_header ist in der flags2 Codec
Kontextfeld
k fügen Sie allen Schlüsselpaketen zusätzliche Daten hinzu
e füge Extradaten zu allen Paketen hinzu
Wenn nicht angegeben, wird davon ausgegangen k.
Zum Beispiel die folgenden ffmpeg Befehl erzwingt einen globalen Header (und deaktiviert somit einzelne
Paket-Header) in den vom "libx264"-Encoder generierten H.264-Paketen, korrigiert diese jedoch
indem Sie den in extradata gespeicherten Header zu den Schlüsselpaketen hinzufügen:
ffmpeg -i INPUT -map 0 -flags:v +global_header -c:v libx264 -bsf:v dump_extra out.ts
h264_mp4toannexb
Konvertieren eines H.264-Bitstreams vom Längenpräfix-Modus in den Startcode-Präfix-Modus (wie
im Anhang B der ITU-T H.264-Spezifikation definiert).
Dies ist für einige Streaming-Formate erforderlich, typischerweise das MPEG-2-Transportstream-Format
("mpegt").
Um beispielsweise eine MP4-Datei, die einen H.264-Stream enthält, in das MPEGts-Format zu remuxen mit ffmpeg,
Sie können den Befehl verwenden:
ffmpeg -i INPUT.mp4 -codec copy -bsf:v h264_mp4toannexb OUTPUT.ts
imxdump
Ändert den Bitstream, damit er in MOV passt und vom Final Cut Pro-Decoder verwendet werden kann. Dies
Filter gilt nur für den MPEG2Video-Codec und wird für Final Cut Pro 7 wahrscheinlich nicht benötigt
und neuer mit den entsprechenden -tag:v.
Um beispielsweise 30 MB/Sek. NTSC IMX in MOV zu remuxen:
ffmpeg -i input.mxf -c copy -bsf:v imxdump -tag:v mx3n output.mov
mjpeg2jpeg
Konvertieren Sie MJPEG/AVI1-Pakete in vollständige JPEG/JFIF-Pakete.
MJPEG ist ein Videocodec, bei dem jeder Videoframe im Wesentlichen ein JPEG-Bild ist. Die
einzelne Frames können verlustfrei extrahiert werden, z. B. durch
ffmpeg -i ../some_mjpeg.avi -c:v copy frames_%d.jpg
Leider sind diese Chunks unvollständige JPEG-Bilder, da ihnen das DHT-Segment fehlt
zur Dekodierung benötigt. Zitat von
<http://www.digitalpreservation.gov/formats/fdd/fdd000063.shtml>:
Avery Lee schrieb 2001 in der Newsgroup rec.video.desktop, dass "MJPEG, or
zumindest das MJPEG in AVIs mit dem MJPG fourcc, ist eingeschränktes JPEG mit einem festen -- und
*weggelassen* -- Huffman-Tisch. Das JPEG muss dem YCbCr-Farbraum entsprechen, es muss 4:2:2 sein und es
muss die grundlegende Huffman-Kodierung verwenden, nicht arithmetisch oder progressiv. . . . Du kannst tatsächlich
Extrahieren Sie die MJPEG-Frames und decodieren Sie sie mit einem normalen JPEG-Decoder, aber Sie müssen
Stellen Sie ihnen das DHT-Segment voran, sonst hat der Decoder keine Ahnung, wie er dekomprimieren soll
die Daten. Die genaue erforderliche Tabelle ist in der OpenDML-Spezifikation angegeben."
Dieser Bitstream-Filter patcht den Header von Frames, die aus einem MJPEG-Stream extrahiert wurden
(mit der AVI1-Header-ID und ohne DHT-Segment), um vollqualifiziertes JPEG zu erzeugen
Bilder.
ffmpeg -i mjpeg-movie.avi -c:v kopieren -bsf:v mjpeg2jpeg frame_%d.jpg
exiftran -i -9 Rahmen*.jpg
ffmpeg -i frame_%d.jpg -c:v Kopie gedreht.avi
mjpega_dump_header
movsub
mp3_header_decompress
mpeg4_unpack_bframes
Entpacken Sie gepackte B-Frames im DivX-Stil.
Gepackte B-Frames im DivX-Stil sind kein gültiges MPEG-4 und waren nur ein Workaround für die defekten
Video für Windows-Subsystem. Sie verbrauchen mehr Speicherplatz, können kleinere AV-Synchronisierungsprobleme verursachen, erfordern
mehr CPU-Leistung zum Decodieren (es sei denn, der Player hat eine decodierte Bildwarteschlange zum Ausgleich
2,0,2,0 Frames pro Paketstil) und verursachen Probleme, wenn sie in einen Standardcontainer kopiert werden
wie mp4 oder mpeg-ps/ts, da MPEG-4-Decoder sie möglicherweise nicht decodieren können, da sie
sind nicht gültig MPEG-4.
Zum Beispiel, um eine AVI-Datei zu reparieren, die einen MPEG-4-Stream mit gepackten B-Frames im DivX-Stil enthält
Verwendung von ffmpeg, können Sie den Befehl verwenden:
ffmpeg -i INPUT.avi -codec copy -bsf:v mpeg4_unpack_bframes OUTPUT.avi
Lärm
Beschädigt den Inhalt von Paketen, ohne den Behälter zu beschädigen. Kann zum Fuzzing verwendet werden oder
Testen von Fehlerresistenz/Verbergen.
Parameter: Eine Ziffernfolge, deren Wert sich darauf bezieht, wie oft ausgegebene Bytes sein werden
geändert. Daher sind Werte kleiner oder gleich 0 verboten, und je niedriger, desto mehr
häufige Bytes werden geändert, wobei 1 bedeutet, dass jedes Byte geändert wird.
ffmpeg -i INPUT -c kopieren -bsf Rauschen[=1] Ausgabe.mkv
wendet die Änderung auf jedes Byte an.
entfernen_extra
FORMAT OPTIONAL
Die Bibliothek libavformat bietet einige generische globale Optionen, die auf allen
Muxer und Demuxer. Darüber hinaus kann jeder Muxer oder Demuxer sogenannte private
Optionen, die für diese Komponente spezifisch sind.
Optionen können eingestellt werden durch Angabe von -zu erhalten Wert in den FFmpeg-Tools oder durch Einstellen der
Wert explizit in den "AVFormatContext"-Optionen oder über die libavutil/opt.h API für
programmatische Verwendung.
Die Liste der unterstützten Optionen folgt:
aviflags Fahnen (Input-Output)
Mögliche Werte:
direkt
Reduzieren Sie die Pufferung.
Sondengröße ganze Zahl (Varianten des Eingangssignals:)
Legen Sie die Sondierungsgröße in Byte fest, dh die Größe der zu analysierenden Daten, um einen Stream zu erhalten
Information. Ein höherer Wert ermöglicht die Erkennung weiterer Informationen, falls dies der Fall ist
in den Stream verteilt, erhöht aber die Latenz. Muss eine ganze Zahl sein, nicht kleiner
als 32. Standardmäßig sind es 5000000.
Paketgröße ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Paketgröße einstellen.
Flaggen Fahnen (Input-Output)
Format-Flags setzen.
Mögliche Werte:
ignidx
Index ignorieren.
Fastseek
Aktivieren Sie schnelle, aber ungenaue Suchvorgänge für einige Formate.
Genpts
PTS generieren.
Nofillin
Geben Sie keine fehlenden Werte ein, die genau berechnet werden können.
nicht analysieren
Deaktivieren Sie AVParsers, dies benötigt auch "+nofillin".
zündet
Ignorieren Sie DTS.
entsorgen
Verwerfen Sie beschädigte Frames.
sortiert
Versuchen Sie, Ausgabepakete durch DTS zu verschachteln.
halten
Seitendaten nicht zusammenführen.
lat
Aktivieren Sie die RTP MP4A-LATM-Nutzlast.
kein Puffer
Reduzieren Sie die durch optionale Pufferung eingeführte Latenz
bitexakt
Schreiben Sie nur plattform-, build- und zeitunabhängige Daten. Dadurch wird sichergestellt, dass die Datei
und Datenprüfsummen sind reproduzierbar und stimmen zwischen Plattformen überein. Seine primäre Verwendung
ist für Regressionstests.
search2any ganze Zahl (Varianten des Eingangssignals:)
Suche nach Nicht-Keyframes auf Demuxer-Ebene zulassen, wenn unterstützt, wenn auf 1 gesetzt. Standard
ist 0.
Analyse ganze Zahl (Varianten des Eingangssignals:)
Geben Sie an, wie viele Mikrosekunden analysiert werden, um die Eingabe zu prüfen. Ein höherer Wert wird
ermöglicht die Erkennung genauerer Informationen, erhöht jedoch die Latenz. Es ist standardmäßig
5,000,000 Mikrosekunden = 5 Sekunden.
Kryptoschlüssel hexadezimal Schnur (Varianten des Eingangssignals:)
Entschlüsselungsschlüssel festlegen.
Indexmem ganze Zahl (Varianten des Eingangssignals:)
Legen Sie den maximalen Speicher fest, der für den Zeitstempelindex verwendet wird (pro Stream).
rtbufsize ganze Zahl (Varianten des Eingangssignals:)
Legen Sie den maximalen Speicher fest, der zum Puffern von Echtzeitframes verwendet wird.
fdebug Fahnen (Input-Output)
Drucken Sie spezifische Debug-Informationen.
Mögliche Werte:
ts
max_verzögerung ganze Zahl (Input-Output)
Legen Sie die maximale Muxing- oder Demuxing-Verzögerung in Mikrosekunden fest.
fpsprobesize ganze Zahl (Varianten des Eingangssignals:)
Legen Sie die Anzahl der Frames fest, die verwendet werden, um fps zu prüfen.
audio_preload ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Legen Sie Mikrosekunden fest, um die Audiopakete früher verschachtelt werden sollen.
chunk_duration ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Stellen Sie Mikrosekunden für jeden Abschnitt ein.
stückgröße ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Legen Sie die Größe in Byte für jeden Block fest.
err_detektieren, f_err_detect Fahnen (Varianten des Eingangssignals:)
Setzen Sie Fehlererkennungs-Flags. "f_err_detect" ist veraltet und sollte nur über verwendet werden
ffmpeg Werkzeug.
Mögliche Werte:
crccheck
Überprüfen Sie eingebettete CRCs.
Bitstream
Erkennen Sie Abweichungen von der Bitstream-Spezifikation.
puffern
Ermitteln Sie eine falsche Bitstream-Länge.
explodieren
Decodierung bei Erkennung kleiner Fehler abbrechen.
vorsichtig
Betrachten Sie Dinge, die gegen die Spezifikation verstoßen und die nicht in freier Wildbahn gesehen wurden, als
Fehler.
konform
Betrachten Sie alle Nichteinhaltungen der Spezifikationen als Fehler.
aggressiv
Betrachten Sie Dinge, die ein vernünftiger Encoder nicht tun sollte, als Fehler.
max_interleave_delta ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Legen Sie die maximale Pufferungsdauer für das Interleaving fest. Die Dauer wird ausgedrückt in
Mikrosekunden und ist standardmäßig auf 1000000 (1 Sekunde) eingestellt.
Um sicherzustellen, dass alle Streams korrekt verschachtelt sind, wartet libavformat, bis es
hat mindestens ein Paket für jeden Stream, bevor tatsächlich Pakete in den geschrieben werden
Ausgabedatei. Wenn einige Streams "sparse" sind (dh es gibt große Lücken zwischen
aufeinanderfolgende Pakete), kann dies zu einer übermäßigen Pufferung führen.
Dieses Feld gibt die maximale Differenz zwischen den Zeitstempeln des ersten und an
das letzte Paket in der Muxing-Warteschlange, über dem libavformat ein Paket ausgibt
unabhängig davon, ob es ein Paket für alle Ströme in die Warteschlange gestellt hat.
Wenn auf 0 gesetzt, puffert libavformat weiterhin Pakete, bis es ein Paket für . hat
jedem Stream, unabhängig von der maximalen Zeitstempeldifferenz zwischen den gepufferten
Pakete.
use_wallclock_as_timestamps ganze Zahl (Varianten des Eingangssignals:)
Verwenden Sie die Wanduhr als Zeitstempel.
vermeiden_negative_ts ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Mögliche Werte:
make_non_negativ
Verschieben Sie Zeitstempel, um sie nicht negativ zu machen. Beachten Sie auch, dass dies nur betrifft
führende negative Zeitstempel und keine nicht monotonen negativen Zeitstempel.
make_zero
Verschieben Sie Zeitstempel, sodass der erste Zeitstempel 0 ist.
Auto (Default)
Aktiviert das Verschieben, wenn das Zielformat dies erfordert.
behindert
Deaktiviert das Verschieben des Zeitstempels.
Wenn die Verschiebung aktiviert ist, werden alle Ausgabezeitstempel um denselben Betrag verschoben. Audio,
Video- und Untertitel-Desynchronisierung und relative Zeitstempelunterschiede bleiben erhalten
im Vergleich dazu, wie sie ohne Verschiebung gewesen wären.
skip_initial_bytes ganze Zahl (Varianten des Eingangssignals:)
Legen Sie die Anzahl der zu überspringenden Bytes fest, bevor Header und Frames gelesen werden, wenn auf 1 gesetzt. Standard ist
0.
korrekt_ts_overflow ganze Zahl (Varianten des Eingangssignals:)
Korrigieren Sie einzelne Zeitstempelüberläufe, wenn auf 1 gesetzt. Der Standardwert ist 1.
Spülpakete ganze Zahl (Möglichkeiten für das Ausgangssignal:)
Leeren Sie den zugrunde liegenden E/A-Stream nach jedem Paket. Standard 1 aktiviert es und hat die
Wirkung der Reduzierung der Latenz; 0 deaktiviert es und kann die Leistung in . leicht erhöhen
manche Fälle.
Output_ts_offset Offset (Möglichkeiten für das Ausgangssignal:)
Legen Sie den Ausgabezeit-Offset fest.
Offset muss eine Zeitdauerangabe sein, siehe Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell.
Der Offset wird vom Muxer zu den Ausgabezeitstempeln hinzugefügt.
Die Angabe eines positiven Offsets bedeutet, dass die entsprechenden Streams um die
Zeitdauer angegeben in Offset. Der Standardwert ist 0 (d.h. kein Offset ist
angewandt).
format_whitelist Liste (Varianten des Eingangssignals:)
"," getrennt Liste der erlaubten Demuxer. Standardmäßig sind alle erlaubt.
dump_separator Schnur (Varianten des Eingangssignals:)
Trennzeichen zum Trennen der Felder, die auf der Befehlszeile über den Stream gedruckt werden
Parameter. Um beispielsweise die Felder mit Zeilenumbrüchen und Einrückungen zu trennen:
ffprobe -dump_separator "
" -ich ~/videos/matrixbench_mpeg2.mpg
Format Strom Bezeichner
Format-Stream-Bezeichner ermöglichen die Auswahl eines oder mehrerer Streams, die mit bestimmten übereinstimmen
Eigenschaften.
Mögliche Formen von Stream-Bezeichnern sind:
stream_index
Entspricht dem Stream mit diesem Index.
stream_type[:stream_index]
stream_type ist einer der folgenden: 'v' für Video, 'a' für Audio, 's' für Untertitel, 'd'
für Daten und 't' für Anhänge. Wenn stream_index gegeben ist, dann entspricht es dem
Stream-Nummer stream_index dieser Art. Ansonsten passt es zu allen Streams davon
Art.
p:Programm-ID[:stream_index]
If stream_index gegeben ist, dann stimmt es mit dem Stream mit der Nummer überein stream_index begann
Programm mit der ID Programm-ID. Andernfalls entspricht es allen Streams im Programm.
#stream_id
Entspricht dem Stream anhand einer formatspezifischen ID.
Die genaue Semantik von Stromspezifizierern wird durch die
"avformat_match_stream_specifier()" Funktion deklariert im libavformat/avformat.h
Header.
DEMUXER
Demuxer sind konfigurierte Elemente in FFmpeg, die die Multimedia-Streams von einem
bestimmten Dateityp.
Wenn Sie Ihren FFmpeg-Build konfigurieren, sind alle unterstützten Demuxer standardmäßig aktiviert.
Sie können alle verfügbaren auflisten, indem Sie die Konfigurationsoption "--list-demuxers" verwenden.
Sie können alle Demuxer mit der Konfigurationsoption "--disable-demuxers" deaktivieren und
Aktivieren Sie selektiv einen einzelnen Demuxer mit der Option "--enable-demuxer=DEMUXER", oder deaktivieren
es mit der Option "--disable-demuxer=DEMUXER".
Die Option "-formats" der ff*-Tools zeigt die Liste der aktivierten Demuxer an.
Die Beschreibung einiger der derzeit verfügbaren Demuxer folgt.
aa
Audible Format 2, 3 und 4 Demuxer.
Dieser Demuxer wird verwendet, um Dateien im Audible-Format 2, 3 und 4 (.aa) zu demuxen.
Apfelhttp
Apple HTTP-Live-Streaming-Demuxer.
Dieser Demuxer präsentiert alle AVStreams aus allen Variantenstreams. Das id-Feld ist auf die eingestellt
Indexnummer der Bitratenvariante. Durch das Setzen der Discard-Flags auf AVStreams (durch Drücken von 'a'
oder 'v' in ffplay) kann der Anrufer entscheiden, welche Streams er tatsächlich empfangen möchte. Die
Gesamtbitrate der Variante, zu der der Stream gehört, ist in einem Metadatenschlüssel verfügbar
namens "variant_bitrate".
apng
Animierter Demuxer für tragbare Netzwerkgrafiken.
Dieser Demuxer wird verwendet, um APNG-Dateien zu demuxen. Alle Header, außer der PNG-Signatur, bis zu (aber
ohne) wird der erste fcTL-Chunk als Extradaten übertragen. Frames werden dann geteilt
als alle Chunks zwischen zwei fcTL-Chunks oder zwischen den letzten fcTL- und IEND-Chunks.
-ignore_loop bool
Ignorieren Sie die Schleifenvariable in der Datei, wenn sie gesetzt ist.
-max_fps int
Maximale Bildrate in Bildern pro Sekunde (0 für kein Limit).
-default_fps int
Standardbildrate in Bildern pro Sekunde, wenn keine in der Datei angegeben ist (0 Bedeutung
so schnell wie möglich).
asf
Demuxer für Advanced Systems Format.
Dieser Demuxer wird verwendet, um ASF-Dateien und MMS-Netzwerkstreams zu demuxen.
-no_resync_search bool
Versuchen Sie nicht, eine Neusynchronisierung durchzuführen, indem Sie nach einem bestimmten optionalen Startcode suchen.
concat
Demuxer für virtuelle Verkettungsskripte.
Dieser Demuxer liest eine Liste von Dateien und anderen Anweisungen aus einer Textdatei und demuxt sie
eins nach dem anderen, als ob alle ihre Pakete zusammengemixt worden wären.
Die Zeitstempel in den Dateien werden so angepasst, dass die erste Datei bei 0 beginnt und jede nächste
Datei beginnt dort, wo die vorherige endet. Beachten Sie, dass dies global erfolgt und dazu führen kann, dass
Lücken, wenn nicht alle Streams genau die gleiche Länge haben.
Alle Dateien müssen die gleichen Streams haben (gleiche Codecs, gleiche Zeitbasis usw.).
Die Dauer jeder Datei wird verwendet, um die Zeitstempel der nächsten Datei anzupassen: wenn die
die Dauer ist falsch (weil sie mit der Bitrate berechnet wurde oder weil die Datei
B. abgeschnitten), kann es zu Artefakten kommen. Die Direktive "duration" kann verwendet werden, um
die in jeder Datei gespeicherte Dauer überschreiben.
Syntax
Das Skript ist eine Textdatei im erweiterten ASCII-Format mit einer Direktive pro Zeile. Leere Zeilen,
führende Leerzeichen und Zeilen, die mit '#' beginnen, werden ignoriert. Die folgende Direktive ist
anerkannt:
"Datei Weg"
Pfad zu einer zu lesenden Datei; Sonderzeichen und Leerzeichen müssen mit Backslash maskiert werden
oder einfache Anführungszeichen.
Alle nachfolgenden dateibezogenen Direktiven gelten für diese Datei.
"ffconcat Version 1.0"
Identifizieren Sie den Skripttyp und die Version. Es setzt auch die Safe Option auf 1, wenn es so wäre
seine Vorgabe -1.
Damit FFmpeg das Format automatisch erkennt, muss diese Anweisung genau vorkommen
wie es ist (kein zusätzliches Leerzeichen oder Byte-Reihenfolge-Markierung) in der allerersten Zeile des Skripts.
"Dauer dur"
Dauer der Datei. Diese Informationen können aus der Datei angegeben werden; es spezifizieren
hier kann es effizienter sein oder helfen, wenn die Informationen aus der Datei nicht verfügbar sind
oder genau.
Wenn die Dauer für alle Dateien eingestellt ist, kann im Ganzen gesucht werden
verkettetes Video.
"inpoint Zeitstempel"
Im Punkt der Datei. Wenn der Demuxer die Datei öffnet, sucht er sofort nach dem
angegebenen Zeitstempel. Es wird gesucht, damit alle Streams erfolgreich präsentiert werden können
am In-Punkt.
Diese Direktive funktioniert am besten mit Intra-Frame-Codecs, denn für Nicht-Intra-Frame-Codecs
Sie erhalten normalerweise zusätzliche Pakete vor dem eigentlichen In-Punkt und dem decodierten Inhalt
wird höchstwahrscheinlich auch Frames vor dem In-Point enthalten.
Für jede Datei haben Pakete vor dem Datei-In-Point Zeitstempel, die kleiner sind als die
berechneten Startzeitstempel der Datei (negativ bei der ersten Datei) und der
die Dauer der Dateien (sofern nicht in der Anweisung "duration" angegeben) wird reduziert
basierend auf ihrem angegebenen In-Punkt.
Aufgrund potenzieller Pakete vor dem angegebenen In-Punkt können Paketzeitstempel
Überlappung zwischen zwei verketteten Dateien.
"outpoint Zeitstempel"
Out-Point der Datei. Wenn der Demuxer den angegebenen Decodierungs-Zeitstempel in . erreicht
einen der Streams behandelt es als Dateiende-Bedingung und überspringt den aktuellen
und alle verbleibenden Pakete aus allen Strömen.
Out-Point ist exklusiv, was bedeutet, dass der Demuxer keine Pakete mit a . ausgibt
Decodierungszeitstempel größer oder gleich dem Out-Punkt.
Diese Anweisung funktioniert am besten mit Intra-Frame-Codecs und -Formaten, bei denen alle Streams vorhanden sind
eng verschachtelt. Für Nicht-Intra-Frame-Codecs erhalten Sie normalerweise zusätzliche
Pakete mit Präsentationszeitstempel nach Out-Point, daher wird der decodierte Inhalt
enthalten höchstwahrscheinlich auch Frames nach dem Out-Point. Wenn deine Streams nicht dicht sind
verschachtelt erhalten Sie möglicherweise nicht alle Pakete aus allen Streams vor dem Out-Punkt und Sie
kann möglicherweise nur den frühesten Stream bis zum Out-Punkt decodieren.
Die Dauer der Dateien (sofern nicht in der Anweisung "duration" angegeben) beträgt
basierend auf dem angegebenen Out-Punkt reduziert.
"file_packet_metadata Schlüssel=Wert"
Metadaten der Pakete der Datei. Die angegebenen Metadaten werden für jede Datei festgelegt
Paket. Sie können diese Anweisung mehrmals angeben, um mehrere Metadaten hinzuzufügen
Einträge.
"Strom"
Führen Sie einen Stream in die virtuelle Datei ein. Alle nachfolgenden Stream-bezogenen Direktiven
gelten für den zuletzt eingeführten Stream. Einige Stream-Eigenschaften müssen festgelegt werden, um
ermöglichen das Identifizieren der übereinstimmenden Streams in den Unterdateien. Wenn keine Streams definiert sind in
dem Skript werden die Streams aus der ersten Datei kopiert.
"exact_stream_id id"
Legen Sie die ID des Streams fest. Wenn diese Direktive angegeben ist, wird die Zeichenfolge mit dem
die entsprechende ID in den Unterdateien wird verwendet. Dies ist besonders nützlich für MPEG-PS
(VOB)-Dateien, bei denen die Reihenfolge der Streams nicht zuverlässig ist.
Optionen
Dieser Demuxer akzeptiert die folgende Option:
Safe
Wenn auf 1 gesetzt, lehnen Sie unsichere Dateipfade ab. Ein Dateipfad gilt als sicher, wenn dies nicht der Fall ist
enthalten eine Protokollspezifikation und sind relativ und alle Komponenten enthalten nur
Zeichen aus dem portablen Zeichensatz (Buchstaben, Ziffern, Punkt, Unterstrich und
Bindestrich) und haben keinen Punkt am Anfang einer Komponente.
Bei 0 wird jeder Dateiname akzeptiert.
Der Standardwert ist -1, entspricht 1 wenn das Format automatisch geprüft wurde und 0
Andernfalls.
auto_convert
Wenn auf 1 gesetzt, versuchen Sie, automatische Konvertierungen der Paketdaten durchzuführen, um die Streams zu erstellen
verkettebar. Der Standardwert ist 1.
Derzeit ist die einzige Konvertierung das Hinzufügen des Bitstream-Filters h264_mp4toannexb zu
H.264-Streams im MP4-Format. Dies ist insbesondere erforderlich, wenn Auflösung
ändert.
flv
Demuxer für das Adobe Flash-Videoformat.
Dieser Demuxer wird verwendet, um FLV-Dateien und RTMP-Netzwerkstreams zu demuxen.
-flv_metadaten bool
Ordnen Sie die Streams gemäß dem Inhalt des onMetaData-Arrays zu.
libgme
Die Game Music Emu-Bibliothek ist eine Sammlung von Emulatoren für Videospiel-Musikdateien.
Sehenhttp://code.google.com/p/game-music-emu/> für weitere Informationen.
Einige Dateien haben mehrere Spuren. Der Demuxer wählt standardmäßig den ersten Track aus. Die
track_index Option kann verwendet werden, um einen anderen Titel auszuwählen. Track-Indizes beginnen bei 0. Die
demuxer exportiert die Anzahl der Tracks als Spuren Metadateneingabe.
Bei sehr großen Dateien ist die maximale Größe Option muss eventuell angepasst werden.
libquvi
Spielen Sie Medien von Internetdiensten mit dem quvi-Projekt ab.
Der Demuxer akzeptiert a Format Möglichkeit, eine bestimmte Qualität anzufordern. Es ist standardmäßig auf eingestellt
beste.
Sehenhttp://quvi.sourceforge.net/> für weitere Informationen.
FFmpeg muss mit "--enable-libquvi" erstellt werden, damit dieser Demuxer aktiviert werden kann.
gif
Animierter GIF-Demuxer.
Es akzeptiert die folgenden Optionen:
min_verzögerung
Legen Sie die minimal gültige Verzögerung zwischen Frames in Hundertstelsekunden fest. Bereich ist 0 bis
6000. Der Standardwert ist 2.
max_gif_delay
Legen Sie die maximal gültige Verzögerung zwischen Frames in Hundertstelsekunden fest. Bereich ist 0 bis
65535. Der Standardwert ist 65535 (fast elf Minuten), der maximal zulässige Wert von
die Spezifikation.
default_delay
Legen Sie die Standardverzögerung zwischen Frames in Hundertstelsekunden fest. Der Bereich ist 0 bis 6000.
Der Standardwert ist 10.
Ignorieren_Schleife
GIF-Dateien können Informationen enthalten, die eine bestimmte Anzahl (oder unendlich) wiederholt werden sollen.
If Ignorieren_Schleife auf 1 gesetzt ist, wird die Loop-Einstellung vom Eingang ignoriert und
Schleifen werden nicht auftreten. Wenn es auf 0 gesetzt ist, wird eine Schleife durchgeführt und die Nummer zyklisch durchlaufen
mal laut GIF. Der Standardwert ist 1.
Platzieren Sie zum Beispiel mit dem Überlagerungsfilter ein sich endlos wiederholendes GIF über einem anderen Video:
ffmpeg -i input.mp4 -ignore_loop 0 -i input.gif -filter_complex overlay=shortest=1 out.mkv
Beachten Sie, dass im obigen Beispiel die kürzeste Option für den Überlagerungsfilter verwendet wird, um die
Ausgabevideo mit der Länge der kürzesten Eingabedatei, die in diesem Fall ist Eingabe.mp4 as
das GIF in diesem Beispiel durchläuft eine Endlosschleife.
image2
Demuxer für Bilddateien.
Dieser Demuxer liest aus einer Liste von Bilddateien, die durch ein Muster angegeben sind. Die Syntax und
Bedeutung des Musters wird durch die Option festgelegt Muster-Art.
Das Muster kann ein Suffix enthalten, das verwendet wird, um das Format von . automatisch zu bestimmen
die in den Dateien enthaltenen Bilder.
Die Größe, das Pixelformat und das Format jedes Bildes müssen für alle Bilder gleich sein
Dateien in der Reihenfolge.
Dieser Demuxer akzeptiert die folgenden Optionen:
Framerate
Legen Sie die Bildrate für den Videostream fest. Der Standardwert ist 25.
Schleife
Wenn auf 1 gesetzt, überschleifen Sie den Eingang. Der Standardwert ist 0.
Muster-Art
Wählen Sie den Mustertyp aus, der verwendet wird, um den angegebenen Dateinamen zu interpretieren.
Muster-Art akzeptiert einen der folgenden Werte.
keine
Mustervergleich deaktivieren, daher enthält das Video nur die angegebenen
Bild. Sie sollten diese Option verwenden, wenn Sie keine Sequenzen erstellen möchten aus
mehrere Bilder und Ihre Dateinamen können Sonderzeichen enthalten.
Reihenfolge
Wählen Sie einen Sequenzmustertyp aus, der verwendet wird, um eine Sequenz von Dateien anzugeben, die nach . indiziert sind
fortlaufende Nummern.
Ein Sequenzmuster kann die Zeichenfolge "%d" oder "%0 . enthaltenNd", was die angibt
Position der Zeichen, die eine fortlaufende Nummer in jedem Dateinamen darstellen
passend zum Muster. Wenn das Formular "%d0Nd" verwendet wird, die Zeichenfolge, die die
Nummer in jedem Dateinamen ist mit 0 aufgefüllt und N ist die Gesamtzahl der mit 0 aufgefüllten Ziffern
die Zahl darstellen. Das Literalzeichen '%' kann im Muster angegeben werden
mit der Zeichenfolge "%%".
Wenn das Sequenzmuster "%d" oder "%0 . enthältNd", der erste Dateiname der Datei
Die durch das Muster angegebene Liste muss eine Zahl enthalten, die zwischen eingeschlossen ist
Startnummer und Startnummer+Startnummernbereich-1 und alle folgenden Zahlen
muss sequentiell sein.
Zum Beispiel entspricht das Muster "img-%03d.bmp" einer Folge von Dateinamen der
unten stehende Formular img-001.bmp, img-002.bmp... img-010.bmp, etc.; das Muster
"i%%m%%g-%d.jpg" loading="lazy" entspricht einer Sequenz von Dateinamen der Form i%m%g-1.jpg,
i%m%g-2.jpg... i%m%g-10.jpg, usw.
Beachten Sie, dass das Muster nicht unbedingt "%d" oder "%0 ." enthalten mussNd", zum Beispiel zu
Konvertieren einer einzelnen Bilddatei img.jpeg Sie können den Befehl verwenden:
ffmpeg -i img.jpeg img.png
Klacks
Wählen Sie einen Glob-Platzhaltermustertyp aus.
Das Muster wird wie ein "glob()"-Muster interpretiert. Dies ist nur wählbar, wenn
libavformat wurde mit Globbing-Unterstützung kompiliert.
glob_sequenz (veraltet, werden wir be entfernt)
Wählen Sie ein gemischtes Glob-Platzhalter-/Sequenzmuster aus.
Wenn Ihre Version von libavformat mit Globbing-Unterstützung kompiliert wurde und die
Das bereitgestellte Muster enthält mindestens ein Glob-Metazeichen unter "%*?[]{}", das heißt
vor einem "%" ohne Escapezeichen wird das Muster wie ein "glob()"-Muster interpretiert,
andernfalls wird es wie ein Sequenzmuster interpretiert.
Allen Glob-Sonderzeichen "%*?[]{}" muss "%" vorangestellt werden. Um zu entkommen
wörtlich "%" verwenden Sie "%%".
Zum Beispiel passt das Muster "foo-%*.jpeg" auf alle Dateinamen mit dem Präfix
"foo-" und endend mit ".jpeg" und "foo-%?%?%?.jpeg" entsprechen allen
Dateinamen mit dem Präfix "foo-", gefolgt von einer Folge von drei Zeichen, und
mit ".jpeg" beenden.
Dieser Mustertyp wird zugunsten von . eingestellt Klacks und Reihenfolge.
Standardwert ist glob_sequenz.
Pixelformat
Legen Sie das Pixelformat der zu lesenden Bilder fest. Wenn nicht angegeben, ist das Pixelformat
aus der ersten Bilddatei in der Sequenz erraten.
Startnummer
Legen Sie den Index der Datei fest, die dem Bilddateimuster entspricht, von dem aus gelesen werden soll.
Der Standardwert ist 0.
Startnummernbereich
Legen Sie den Indexintervallbereich fest, der bei der Suche nach der ersten Bilddatei im
Reihenfolge, beginnend mit Startnummer. Der Standardwert ist 5.
ts_from_file
Wenn auf 1 gesetzt, wird der Frame-Zeitstempel auf die Änderungszeit der Bilddatei gesetzt. Beachten Sie, dass
Monotonie der Zeitstempel ist nicht vorgesehen: Bilder gehen in der gleichen Reihenfolge wie ohne diese
Möglichkeit. Der Standardwert ist 0. Wenn auf 2 gesetzt, wird der Frame-Zeitstempel auf die Änderung gesetzt
Zeit der Bilddatei in Nanosekunden-Präzision.
Video Größe
Legen Sie die Videogröße der zu lesenden Bilder fest. Wenn nicht angegeben, wird die Videogröße geschätzt
aus der ersten Bilddatei in der Sequenz.
Beispiele
· Verwenden ffmpeg zum Erstellen eines Videos aus den Bildern in der Dateisequenz img-001.jpeg,
img-002.jpeg, ..., unter Annahme einer Eingangsbildrate von 10 Bildern pro Sekunde:
ffmpeg -framerate 10 -i 'img-%03d.jpeg' out.mkv
· Wie oben, jedoch lesen Sie zunächst aus einer Datei mit dem Index 100 in der Reihenfolge:
ffmpeg -framerate 10 -start_number 100 -i 'img-%03d.jpeg' out.mkv
· Bilder lesen, die dem "*.png" loading="lazy"-Glob-Muster entsprechen, das sind alle Dateien, die mit enden
das Suffix ".png" loading="faul":
ffmpeg -framerate 10 -pattern_type glob -i "*.png" loading="faul" out.mkv
mov/mp4/3gp/Quicktme
Quicktime / MP4-Demuxer.
Dieser Demuxer akzeptiert die folgenden Optionen:
enable_drefs
Aktivieren Sie das Laden externer Spuren, standardmäßig deaktiviert. Aktivieren dieser Dose
theoretisch in einigen Anwendungsfällen Informationen verlieren.
use_absolute_path
Ermöglicht das Laden externer Spuren über absolute Pfade, standardmäßig deaktiviert. Aktivieren
dies stellt ein Sicherheitsrisiko dar. Sie sollte nur aktiviert werden, wenn die Quelle als nicht bekannt ist
bösartig.
mpegs
MPEG-2-Transportstrom-Demuxer.
Dieser Demuxer akzeptiert die folgenden Optionen:
resync_size
Legen Sie die Größenbeschränkung für die Suche nach einer neuen Synchronisierung fest. Der Standardwert ist 65536.
fix_teletext_pts
Überschreiben Sie die PTS- und DTS-Werte von Videotextpaketen mit den Zeitstempeln, die aus den berechneten
PCR des ersten Programms, zu dem der Videotextstrom gehört und wird nicht verworfen.
Der Standardwert ist 1, setzen Sie diese Option auf 0, wenn Sie Ihr Videotextpaket PTS und DTS
Werte unberührt.
ts_packetsize
Ausgabeoption, die die rohe Paketgröße in Bytes enthält. Zeigen Sie das erkannte Rohpaket an
Größe, kann nicht vom Benutzer eingestellt werden.
scan_all_pmts
Scannen und kombinieren Sie alle PMTs. Der Wert ist eine ganze Zahl mit einem Wert von -1 bis 1 (-1 bedeutet
automatische Einstellung, 1 bedeutet aktiviert, 0 bedeutet deaktiviert). Der Standardwert ist -1.
Rohvideo
Raw-Video-Demuxer.
Dieser Demuxer ermöglicht das Lesen von Rohvideodaten. Da es keinen Header gibt, der die
angenommenen Videoparameter, muss der Benutzer diese angeben, um die
Daten richtig.
Dieser Demuxer akzeptiert die folgenden Optionen:
Framerate
Stellen Sie die Bildrate des Eingangsvideos ein. Der Standardwert ist 25.
Pixelformat
Legen Sie das Pixelformat des Eingangsvideos fest. Der Standardwert ist "yuv420p".
Video Größe
Stellen Sie die Eingangsvideogröße ein. Dieser Wert muss explizit angegeben werden.
Zum Beispiel um eine Rawvideo-Datei zu lesen Eingabe.raw mit ffplay, unter der Annahme eines Pixelformats von
"rgb24", einer Videogröße von "320x240" und einer Bildrate von 10 Bildern pro Sekunde, verwenden Sie die
Befehl:
ffplay -f rawvideo -pixel_format rgb24 -video_size 320x240 -Framerate 10 input.raw
sbg
SBaGen-Skript-Demuxer.
Dieser Demuxer liest die Skriptsprache von SBaGenhttp://uazu.net/sbagen/> bis
binaurale Beats-Sessions generieren. Ein SBG-Skript sieht so aus:
-SE
a: 300-2.5/3 440+4.5/0
b: 300-2.5/0 440+4.5/3
aus: -
JETZT == a
+0:07:00 == b
+0:14:00 == ein
+0:21:00 == b
+0:30:00 aus
Ein SBG-Skript kann absolute und relative Zeitstempel mischen. Wenn das Skript nur eines verwendet
absolute Zeitstempel (einschließlich der Startzeit des Skripts) oder nur relative, dann ist es
Layout ist fest und die Konvertierung ist unkompliziert. Auf der anderen Seite, wenn das Skript
mischt beide Arten von Zeitstempeln, dann die JETZT Referenz für relative Zeitstempel ist
entnommen aus der aktuellen Tageszeit zum Zeitpunkt des Lesens des Skripts und dem Skript-Layout
wird entsprechend dieser Referenz eingefroren. Das heißt, wenn das Skript direkt ist
abgespielt werden, stimmen die tatsächlichen Zeiten mit den absoluten Zeitstempeln bis zu den des Soundcontrollers überein
Taktgenauigkeit, aber wenn der Benutzer die Wiedergabe irgendwie pausiert oder sucht, werden alle Zeiten
entsprechend verschoben.
Bildunterschriften
JSON-Untertitel verwendet fürhttp://www.ted.com/>.
TED stellt keine Links zu den Bildunterschriften zur Verfügung, sie können jedoch von der Seite aus erraten werden. Die
Datei tools/bookmarklets.html aus dem FFmpeg-Quellbaum enthält ein Bookmarklet zum Freilegen
Them.
Dieser Demuxer akzeptiert die folgende Option:
Startzeit
Stellen Sie die Startzeit des TED-Gesprächs in Millisekunden ein. Der Standardwert ist 15000 (15s). es ist
verwendet, um die Untertitel mit den herunterladbaren Videos zu synchronisieren, da sie eine 15s . enthalten
Einführung.
Beispiel: Konvertieren Sie die Untertitel in ein Format, das die meisten Spieler verstehen:
ffmpeg-i http://www.ted.com/talks/subtitles/id/1/lang/en talk1-de.srt
MUXER
Muxer sind konfigurierte Elemente in FFmpeg, die es ermöglichen, Multimedia-Streams in eine Datei zu schreiben
bestimmten Dateityp.
Wenn Sie Ihren FFmpeg-Build konfigurieren, sind alle unterstützten Muxer standardmäßig aktiviert. Du
kann mit der Konfigurationsoption "--list-muxers" alle verfügbaren Muxer auflisten.
Sie können alle Muxer mit der Konfigurationsoption „--disable-muxers“ und deaktivieren
selektiv einzelne Muxer aktivieren / deaktivieren mit den Optionen "--enable-muxer=MUXER" /
"--disable-muxer=MUXER".
Die Option "-formats" der ff*-Tools zeigt die Liste der aktivierten Muxer an.
Es folgt eine Beschreibung einiger der derzeit verfügbaren Muxer.
aIFF
Muxer für Audio-Interchange-Dateiformate.
Optionen
Es akzeptiert die folgenden Optionen:
write_id3v2
Aktivieren Sie das Schreiben von ID3v2-Tags, wenn auf 1 gesetzt. Die Standardeinstellung ist 0 (deaktiviert).
id3v2_version
Wählen Sie die ID3v2-Version zum Schreiben aus. Derzeit nur Version 3 und 4 (auch bekannt als ID3v2.3 und
ID3v2.4) werden unterstützt. Die Standardeinstellung ist Version 4.
crc
CRC-Testformat (Cyclic Redundancy Check).
Dieser Muxer berechnet und druckt den Adler-32 CRC aller eingegebenen Audio- und Videobilder.
Standardmäßig werden Audioframes in signierte 16-Bit-Roh-Audio und Videoframes in Raw konvertiert
Video, bevor Sie den CRC berechnen.
Die Ausgabe des Muxers besteht aus einer einzelnen Zeile der Form: CRC=0xCRC, Wobei CRC ist eine
Hexadezimalzahl 0-aufgefüllt mit 8 Stellen, die den CRC für alle decodierten Eingaben enthalten
Frames.
Siehe auch die Framecrc Muxer.
Beispiele
Zum Beispiel, um den CRC der Eingabe zu berechnen und in der Datei zu speichern aus.crc:
ffmpeg -i EINGABE -f crc aus.crc
Sie können die CRC mit dem Befehl auf stdout drucken:
ffmpeg -i EINGANG -f crc -
Sie können das Ausgabeformat jedes Frames mit auswählen ffmpeg durch Angabe des Audios und
Video-Codec und -Format. Zum Beispiel, um den CRC des in PCM . konvertierten Eingangsaudios zu berechnen
8-Bit ohne Vorzeichen und das Eingabevideo in MPEG-2-Video konvertiert, verwenden Sie den Befehl:
ffmpeg -i EINGANG -c:a pcm_u8 -c:v mpeg2video -f crc -
Framecrc
CRC-Testformat (Cyclic Redundancy Check) pro Paket.
Dieser Muxer berechnet und druckt den Adler-32 CRC für jedes Audio- und Videopaket. Von
Standard-Audioframes werden in signiertes 16-Bit-Rohaudio und Videoframes in Rohformat konvertiert
Video, bevor Sie den CRC berechnen.
Die Ausgabe des Muxers besteht aus einer Zeile für jedes Audio- und Videopaket der Form:
, , , , , 0x
CRC ist eine mit 0 auf 8 Ziffern aufgefüllte Hexadezimalzahl, die den CRC des Pakets enthält.
Beispiele
Um beispielsweise den CRC der Audio- und Videoframes in zu berechnen SPEISUNG, umgewandelt in roh
Audio- und Videopakete und speichern Sie sie in der Datei aus.crc:
ffmpeg -i INPUT -f framecrc aus.crc
Um die Informationen auf stdout zu drucken, verwenden Sie den Befehl:
ffmpeg -i INPUT -f framecrc -
Mit ffmpeg, können Sie das Ausgabeformat für die Audio- und Videobilder auswählen
codiert, bevor der CRC für jedes Paket berechnet wird, indem der Audio- und Videocodec angegeben wird.
Um beispielsweise den CRC jedes decodierten Eingangsaudioframes zu berechnen, der in PCM . umgewandelt wurde
8-Bit ohne Vorzeichen und von jedem decodierten Eingangsvideobild, das in MPEG-2-Video konvertiert wurde, verwenden Sie die
Befehl:
ffmpeg -i EINGANG -c:a pcm_u8 -c:v mpeg2video -f framecrc -
Siehe auch die crc Muxer.
Framemd5
MD5-Testformat pro Paket.
Dieser Muxer berechnet und druckt den MD5-Hash für jedes Audio- und Videopaket. Standardmäßig
Audio-Frames werden zuvor in signiertes 16-Bit-Roh-Audio und Video-Frames in Roh-Video konvertiert
den Hash berechnen.
Die Ausgabe des Muxers besteht aus einer Zeile für jedes Audio- und Videopaket der Form:
, , , , ,
MD5 ist eine hexadezimale Zahl, die den berechneten MD5-Hash für das Paket darstellt.
Beispiele
Um zum Beispiel den MD5 der Audio- und Videoframes in zu berechnen SPEISUNG, umgewandelt in roh
Audio- und Videopakete und speichern Sie sie in der Datei aus.md5:
ffmpeg -i INPUT -f framemd5 out.md5
Um die Informationen auf stdout zu drucken, verwenden Sie den Befehl:
ffmpeg -i EINGANG -f framemd5 -
Siehe auch die md5 Muxer.
gif
Animierter GIF-Muxer.
Es akzeptiert die folgenden Optionen:
Schleife
Legen Sie fest, wie oft die Ausgabe wiederholt werden soll. Verwenden Sie "-1" für keine Schleife, 0 für Schleifen
auf unbestimmte Zeit (Standard).
final_delay
Erzwinge die Verzögerung (ausgedrückt in Centisekunden) nach dem letzten Frame. Jeder Rahmen endet mit
eine Verzögerung bis zum nächsten Frame. Der Standardwert ist "-1", was ein spezieller Wert ist, der angegeben werden muss
den Muxer, um die vorherige Verzögerung wiederzuverwenden. Im Falle einer Schleife möchten Sie vielleicht anpassen
dieser Wert, um beispielsweise eine Pause zu markieren.
Um beispielsweise ein GIF zu codieren, das 10 Mal wiederholt wird, mit einer Verzögerung von 5 Sekunden zwischen den Schleifen:
ffmpeg -i INPUT -loop 10 -final_delay 500 out.gif
Hinweis 1: Wenn Sie die Frames in separate GIF-Dateien extrahieren möchten, müssen Sie die
image2 Muxer:
ffmpeg -i INPUT -c:v gif -f image2 "out%d.gif"
Hinweis 2: Das GIF-Format hat eine sehr kleine Zeitbasis: Die Verzögerung zwischen zwei Bildern kann nicht sein
kleiner als eine Centi Sekunde.
hls
Apple HTTP Live Streaming Muxer, der MPEG-TS gemäß dem HTTP Live Streaming segmentiert
(HLS)-Spezifikation.
Es erstellt eine Playlist-Datei und eine oder mehrere Segmentdateien. Der Ausgabedateiname gibt an
den Dateinamen der Wiedergabeliste.
Standardmäßig erstellt der Muxer für jedes produzierte Segment eine Datei. Diese Dateien haben das gleiche
Name als Playlist, gefolgt von einer fortlaufenden Nummer und einer .ts-Erweiterung.
Um beispielsweise eine Eingabedatei mit zu konvertieren ffmpeg:
ffmpeg -i in.nut out.m3u8
In diesem Beispiel wird die Wiedergabeliste erstellt, aus.m3u8, und Segmentdateien: out0.ts, out1.ts,
out2.ts, usw.
Siehe auch die Segment Muxer, der eine allgemeinere und flexiblere Implementierung von a
Segmentierer und kann verwendet werden, um eine HLS-Segmentierung durchzuführen.
Optionen
Dieser Muxer unterstützt die folgenden Optionen:
hls_time Sekunden
Legen Sie die Segmentlänge in Sekunden fest. Der Standardwert ist 2.
hls_list_size Größe
Legen Sie die maximale Anzahl von Playlist-Einträgen fest. Wenn auf 0 gesetzt, enthält die Listendatei alle
die Segmente. Der Standardwert ist 5.
hls_ts_options Optionen_Liste
Legen Sie Ausgabeformatoptionen mithilfe einer :-getrennten Liste von Schlüssel=Wert-Parametern fest. Werte
Sonderzeichen mit ":" müssen mit Escapezeichen versehen werden.
hls_wrap wickeln
Legen Sie die Nummer fest, nach der die Nummer des Segmentdateinamens (die in jedem
Segmentdatei) umschließt. Bei 0 wird die Zahl nie umgebrochen. Der Standardwert ist 0.
Diese Option ist nützlich, um zu vermeiden, dass die Festplatte mit vielen Segmentdateien gefüllt wird, und begrenzt
die maximale Anzahl von Segmentdateien, die auf die Festplatte geschrieben werden wickeln.
Startnummer Anzahl
Starten Sie die Playlist-Sequenznummer von Anzahl. Der Standardwert ist 0.
hls_allow_cache erlaubencache
Legen Sie explizit fest, ob der Client KANN \fIst0(1) oder MUSS NICHT \fIst0(0) Cache-Medien
Segmente.
hls_base_url Basis-URL
Anhängen Basis-URL zu jedem Eintrag in der Playlist. Nützlich zum Generieren von Wiedergabelisten mit
absolute Pfade.
Beachten Sie, dass die Sequenznummer der Wiedergabeliste für jedes Segment eindeutig sein muss und nicht
zu verwechseln mit der Sequenznummer des Segmentdateinamens, die zyklisch sein kann, z
Beispiel, wenn die wickeln Option ist angegeben.
hls_segment_dateiname Dateinamen
Legen Sie den Namen der Segmentdatei fest. Es sei denn, hls_flags single_file ist festgelegt Dateinamen wird verwendet als
String-Format mit der Segmentnummer:
ffmpeg in.nut -hls_segment_filename 'file%03d.ts' out.m3u8
In diesem Beispiel wird die Wiedergabeliste erstellt, aus.m3u8, und Segmentdateien: file000.ts,
file001.ts, file002.ts, usw.
hls_key_info_file key_info_file
Verwenden Sie die Informationen in key_info_file zur Segmentverschlüsselung. Die erste Zeile von
key_info_file gibt den Schlüssel-URI an, der in die Wiedergabeliste geschrieben wird. Die Schlüssel-URL wird verwendet, um
während der Wiedergabe auf den Verschlüsselungsschlüssel zugreifen. Die zweite Zeile gibt den Pfad zum
Schlüsseldatei, die zum Abrufen des Schlüssels während des Verschlüsselungsprozesses verwendet wird. Die Schlüsseldatei wird gelesen als
ein einzelnes gepacktes Array von 16 Oktetten im Binärformat. Die optionale dritte Zeile gibt an
der Initialisierungsvektor (IV) als hexadezimaler String, der anstelle des
Segmentsequenznummer (Standard) für die Verschlüsselung. Änderungen an key_info_file wird resultieren
bei Segmentverschlüsselung mit dem neuen Schlüssel/IV und einem Eintrag in der Playlist für den neuen Schlüssel
URI/IV.
Dateiformat der Schlüsselinformationen:
(Optional)
Beispiele für Schlüssel-URIs:
http://server/file.key
/Pfad/zu/Datei.Schlüssel
file.key
Beispiele für Schlüsseldateipfade:
file.key
/Pfad/zu/Datei.Schlüssel
Beispiel IV:
0123456789ABCDEF0123456789ABCDEF
Beispiel für eine Schlüsselinfodatei:
http://server/file.key
/Pfad/zu/Datei.Schlüssel
0123456789ABCDEF0123456789ABCDEF
Beispiel Shell-Skript:
#!/ Bin / sh
BASE_URL=${1:-'.'}
openssl rand 16 > file.key
echo $BASE_URL/file.key > file.keyinfo
echo file.key >> file.keyinfo
echo $(openssl rand -hex 16) >> file.keyinfo
ffmpeg -f lavfi -re -i testrc -c:v h264 -hls_flags delete_segments \
-hls_key_info_file file.keyinfo out.m3u8
hls_flags einzelne Datei
Wenn dieses Flag gesetzt ist, speichert der Muxer alle Segmente in einer einzigen MPEG-TS-Datei und
verwendet Byte-Bereiche in der Wiedergabeliste. Auf diese Weise generierte HLS-Wiedergabelisten haben
die Versionsnummer 4. Zum Beispiel:
ffmpeg -i in.nut -hls_flags single_file out.m3u8
Werde die Playlist produzieren, aus.m3u8, und eine einzelne Segmentdatei, aus.ts.
hls_flags delete_segments
Aus der Playlist entfernte Segmentdateien werden nach einem Zeitraum von gelöscht
die Dauer des Segments plus die Dauer der Playlist.
ico
ICO-Datei-Muxer.
Das Symboldateiformat (ICO) von Microsoft unterliegt einigen strengen Einschränkungen, die beachtet werden sollten:
· Größe darf 256 Pixel in keiner Dimension überschreiten
· Es können nur BMP- und PNG-Bilder gespeichert werden
· Wenn ein BMP-Bild verwendet wird, muss es eines der folgenden Pixelformate aufweisen:
BMP-Bittiefe FFmpeg-Pixelformat
1bit Kumpel8
4bit Kumpel8
8bit Kumpel8
16bit RGB555le
24bit bgr24
32-Bit-BGRA
· Wenn ein BMP-Bild verwendet wird, muss es den BITMAPINFOHEADER DIB-Header verwenden
· Wenn ein PNG-Bild verwendet wird, muss es das rgba-Pixelformat verwenden
image2
Bilddatei-Muxer.
Der Bilddatei-Muxer schreibt Videoframes in Bilddateien.
Die Ausgabedateinamen werden durch ein Muster angegeben, das verwendet werden kann, um sequentiell zu produzieren
nummerierte Dateireihe. Das Muster kann die Zeichenfolge „%d“ oder „%0“ enthaltenNd", diese Zeichenfolge
gibt die Position der Zeichen an, die eine Nummerierung in den Dateinamen darstellen. Wenn die
Formular "%0Nd" verwendet wird, wird die Zeichenfolge, die die Zahl in jedem Dateinamen darstellt, mit 0 aufgefüllt bis N
Ziffern. Das Literalzeichen „%“ kann im Muster mit der Zeichenfolge „%%“ angegeben werden.
Wenn das Muster "%d" oder "%0 . enthältNd", wird der erste Dateiname der angegebenen Dateiliste
die Zahl 1 enthalten, alle folgenden Zahlen werden fortlaufend sein.
Das Muster kann ein Suffix enthalten, das verwendet wird, um das Format von . automatisch zu bestimmen
die zu schreibenden Bilddateien.
Zum Beispiel wird das Muster "img-%03d.bmp" eine Folge von Dateinamen der Form angeben
img-001.bmp, img-002.bmp... img-010.bmp, usw. Das Muster "img%%-%d.jpg" loading="lazy" wird angeben
eine Folge von Dateinamen der Form Bild%-1.jpg, Bild%-2.jpg... Bild%-10.jpg, usw.
Beispiele
Das folgende Beispiel zeigt die Verwendung von ffmpeg zum Erstellen einer Dateifolge
img-001.jpeg, img-002.jpeg, ..., nimmt jede Sekunde ein Bild aus dem Eingangsvideo:
ffmpeg -i in.avi -vsync 1 -r 1 -f image2 'img-%03d.jpeg'
Beachten Sie, dass mit ffmpeg, wenn das Format nicht mit der Option "-f" angegeben wird und die Ausgabe
filename gibt ein Bilddateiformat an, der image2-Muxer wird automatisch ausgewählt, also
Der vorherige Befehl kann wie folgt geschrieben werden:
ffmpeg -i in.avi -vsync 1 -r 1 'img-%03d.jpeg'
Beachten Sie auch, dass das Muster nicht unbedingt "%d" oder "%0 ." enthalten mussNd", zum Beispiel zu
eine einzelne Bilddatei erstellen img.jpeg aus dem Eingabevideo können Sie den Befehl verwenden:
ffmpeg -i in.avi -f image2 -frames:v 1 img.jpeg
Die strftime Mit dieser Option können Sie den Dateinamen um Datums- und Uhrzeitinformationen erweitern.
Die Syntax finden Sie in der Dokumentation der Funktion "strftime()".
Um beispielsweise Bilddateien aus dem Muster "strftime()" "%Y-%m-%d_%H-%M-%S" zu generieren,
Folgende ffmpeg Befehl kann verwendet werden:
ffmpeg -f v4l2 -r 1 -i /dev/video0 -f image2 -strftime 1 "%Y-%m-%d_%H-%M-%S.jpg"
Optionen
Startnummer
Starten Sie die Sequenz ab der angegebenen Nummer. Der Standardwert ist 0.
Aktualisierung
Wenn der Wert auf 1 gesetzt ist, wird der Dateiname immer nur als Dateiname und nicht als Dateiname interpretiert
Muster, und die entsprechende Datei wird fortlaufend mit neuen Bildern überschrieben.
Der Standardwert ist 0.
strftime
Wenn auf 1 gesetzt, erweitern Sie den Dateinamen mit Datums- und Uhrzeitinformationen von "strftime()".
Der Standardwert ist 0.
Der Bild-Muxer unterstützt das .YUV-Bilddateiformat. Das Besondere an diesem Format ist das
Jeder Bildrahmen besteht aus drei Dateien für jede der YUV420P-Komponenten. Zum Lesen bzw
Schreiben Sie dieses Bilddateiformat und geben Sie den Namen der „.Y“-Datei an. Der Muxer wird es tun
Öffnen Sie automatisch die '.U'- und '.V'-Dateien nach Bedarf.
Matroska
Matroska Container-Muxer.
Dieser Muxer implementiert die Matroska- und Webm-Containerspezifikationen.
Metadaten
Die erkannten Metadateneinstellungen in diesem Muxer sind:
Titel
Stellen Sie den Titelnamen ein, der einem einzelnen Track zugewiesen wird.
Sprache
Geben Sie die Sprache des Tracks im Formular Matroska-Sprachen an.
Die Sprache kann entweder das bibliographische ISO-3-639 (ISO 2-639/B)-Formular mit 2 Buchstaben sein
(wie „fre“ für Französisch) oder ein Sprachcode gemischt mit einem Ländercode für Spezialitäten
in Sprachen (wie "fre-ca" für kanadisches Französisch).
stereo_modus
Legen Sie ein Stereo-3D-Videolayout für zwei Ansichten in einer einzigen Videospur fest.
Folgende Werte werden erkannt:
Mono
Video ist nicht stereo
links rechts
Beide Ansichten sind nebeneinander angeordnet, die Ansicht für das linke Auge befindet sich links
unten oben
Beide Ansichten sind in der Ausrichtung von oben nach unten angeordnet, die Ansicht für das linke Auge befindet sich unten
oben unten
Beide Ansichten sind in der Ausrichtung von oben nach unten angeordnet, die Ansicht für das linke Auge ist oben
Schachbrett_rl
Jede Ansicht ist in einem schachbrettartig verschachtelten Muster angeordnet, wobei die Ansicht für das linke Auge gilt
zuerst
Schachbrett_lr
Jede Ansicht ist in einem schachbrettartig verschachtelten Muster angeordnet, wobei es sich um die Ansicht für das rechte Auge handelt
zuerst
row_interleaved_rl
Jede Ansicht besteht aus einer zeilenbasierten Verschachtelung, die Ansicht für das rechte Auge ist die erste Zeile
row_interleaved_lr
Jede Ansicht besteht aus einer zeilenbasierten Verschachtelung, die Ansicht für das linke Auge ist die erste Zeile
col_interleaved_rl
Beide Ansichten sind in einer spaltenbasierten Verschachtelung angeordnet, die Ansicht für das rechte Auge ist
erste Spalte
col_interleaved_lr
Beide Ansichten sind in einer spaltenbasierten Verschachtelung angeordnet, die Ansicht für das linke Auge ist
erste Spalte
anaglyph_cyan_rot
Alle Bilder sind im Anaglyphenformat sichtbar durch Rot-Cyan-Filter
rechts links
Beide Ansichten sind nebeneinander angeordnet, die rechte Ansicht ist links
anaglyph_green_magenta
Alle Frames sind im Anaglyphenformat sichtbar durch Grün-Magenta-Filter
block_lr
Beide Augen in einem Block verbunden, die Ansicht mit dem linken Auge ist zuerst
block_rl
Beide Augen in einem Block verbunden, die rechte Augenansicht ist zuerst
Beispielsweise kann ein 3D-WebM-Clip mit der folgenden Befehlszeile erstellt werden:
ffmpeg -i sample_left_right_clip.mpg -an -c:v libvpx -metadata stereo_mode=left_right -y stereo_clip.webm
Optionen
Dieser Muxer unterstützt die folgenden Optionen:
Reserve_Index_Space
Standardmäßig schreibt dieser Muxer den Index für die Suche (in Matroska-Begriffen Cues genannt) unter
am Ende der Datei, da es nicht im Voraus wissen kann, wie viel Platz dafür übrig bleibt
Index am Anfang der Datei. Für einige Anwendungsfälle – z. B. Streaming
Wenn die Suche möglich, aber langsam ist, ist es sinnvoll, den Index an den Anfang zu stellen
der Datei.
Wenn diese Option auf einen Wert ungleich Null gesetzt ist, reserviert der Muxer eine bestimmte Menge an
Platz im Dateikopf und versuchen Sie dann, beim Muxen die Hinweise dort zu schreiben
beendet. Wenn der verfügbare Speicherplatz nicht ausreicht, schlägt das Muxen fehl. Eine sichere Größe für
Die meisten Anwendungsfälle sollten etwa 50 kB pro Stunde Video betragen.
Beachten Sie, dass Cues nur geschrieben werden, wenn die Ausgabe durchsuchbar ist und diese Option keine
Wirkung, wenn nicht.
md5
MD5-Testformat.
Dieser Muxer berechnet und druckt den MD5-Hash aller eingegebenen Audio- und Videoframes. Von
Standard-Audioframes werden in signiertes 16-Bit-Rohaudio und Videoframes in Rohformat konvertiert
Video, bevor Sie den Hash berechnen.
Die Ausgabe des Muxers besteht aus einer einzelnen Zeile der Form: MD5=MD5, Wobei MD5 ist eine
Hexadezimalzahl, die den berechneten MD5-Hash darstellt.
Zum Beispiel, um den MD5-Hash der in Rohaudio und -video konvertierten Eingabe zu berechnen, und
in der Datei speichern aus.md5:
ffmpeg -i EINGANG -f md5 out.md5
Sie können das MD5 mit dem Befehl auf stdout drucken:
ffmpeg -i EINGANG -f md5 -
Siehe auch die Framemd5 Muxer.
bewegen, mp4, ismv
MOV/MP4/ISMV-Muxer (Smooth Streaming).
Der Muxer mov/mp4/ismv unterstützt die Fragmentierung. Normalerweise enthält eine MOV/MP4-Datei alle
Metadaten zu allen Paketen, die an einem Ort gespeichert sind (am Ende der Datei geschrieben, kann es
durch Hinzufügen an den Anfang verschoben werden, um eine bessere Wiedergabe zu ermöglichen schneller Start zu den Bewegungsflagsoder mit
qt-faststart Werkzeug). Eine fragmentierte Datei besteht aus einer Reihe von Fragmenten, wobei Pakete
und Metadaten zu diesen Paketen werden zusammen gespeichert. Das Schreiben einer fragmentierten Datei hat die
Vorteil, dass die Datei auch dann dekodierbar ist, wenn der Schreibvorgang unterbrochen wird (während ein normaler
MOV/MP4 ist nicht dekodierbar, wenn es nicht richtig fertig ist) und benötigt weniger Speicher, wenn
Schreiben von sehr langen Dateien (da das Schreiben von normalen MOV/MP4-Dateien Informationen zu jedem einzelnen speichert
Paket im Speicher, bis die Datei geschlossen wird). Der Nachteil ist, dass es weniger kompatibel ist
mit anderen Anwendungen.
Optionen
Die Fragmentierung wird aktiviert, indem eine der AVOptions eingestellt wird, die das Schneiden der Datei definiert
in Fragmente:
-moov_size Bytes
Reserviert Platz für das moov-Atom am Anfang der Datei, anstatt das
moov-Atom am Ende. Wenn der reservierte Platz nicht ausreicht, schlägt das Muxen fehl.
-Movflags frag_keyframe
Starten Sie bei jedem Video-Keyframe ein neues Fragment.
-frag_duration Dauer
Erstellen Sie Fragmente, die Dauer Mikrosekunden lang.
-frag_size Größe
Fragmente erstellen, die bis zu . enthalten Größe Byte Nutzdaten.
-Movflags frag_benutzerdefiniert
Ermöglichen Sie dem Anrufer, manuell auszuwählen, wann Fragmente geschnitten werden sollen, indem Sie ihn anrufen
„av_write_frame(ctx, NULL)“, um ein Fragment mit den bisher geschriebenen Paketen zu schreiben. (Das
ist nur mit anderen Anwendungen nützlich, die libavformat integrieren, nicht mit ffmpeg.)
-min_frag_duration Dauer
Erstellen Sie keine Fragmente, die kürzer sind als Dauer Mikrosekunden lang.
Wenn mehr als eine Bedingung angegeben ist, werden Fragmente geschnitten, wenn eine der angegebenen Bedingungen erfüllt ist
Bedingungen erfüllt ist. Die Ausnahme hiervon ist "-min_frag_duration", die sein muss
erfüllt sind, damit alle anderen Bedingungen zutreffen.
Darüber hinaus kann die Schreibweise der Ausgabedatei durch einige andere Einstellungen angepasst werden
Optionen:
-Movflags leer_moov
Schreiben Sie ein erstes moov-Atom direkt an den Anfang der Datei, ohne eines zu beschreiben
Proben darin. Im Allgemeinen wird ein mdat/moov-Paar am Anfang der Datei geschrieben, als a
normale MOV/MP4-Datei, die nur einen kurzen Teil der Datei enthält. Mit dieser Option
Set gibt es kein anfängliches mdat-Atom und das moov-Atom beschreibt nur die Spuren, aber
hat eine Null-Dauer.
Diese Option wird beim Schreiben von ismv-Dateien (Smooth Streaming) implizit festgelegt.
-Movflags separate_moof
Schreiben Sie für jeden Track ein separates Moof-Atom (Filmfragment). Normalerweise Pakete für alle
Tracks werden in einem Moof-Atom geschrieben (was etwas effizienter ist), aber mit diesem
Option gesetzt, schreibt der Muxer ein moof/mdat-Paar für jede Spur, was die
getrennte Spuren.
Diese Option wird beim Schreiben von ismv-Dateien (Smooth Streaming) implizit festgelegt.
-Movflags schneller Start
Führen Sie einen zweiten Durchgang durch, indem Sie den Index (moov atom) an den Anfang der Datei verschieben. Dies
Der Vorgang kann eine Weile dauern und funktioniert in verschiedenen Situationen nicht, z
Ausgabe, daher ist sie standardmäßig nicht aktiviert.
-Movflags rtphint
Fügen Sie RTP-Hinweisspuren zur Ausgabedatei hinzu.
-Movflags deaktivieren_chpl
Deaktivieren Sie die Nero-Kapitelmarkierungen (chpl-Atom). Normalerweise sind sowohl Nero-Kapitel als auch a
QuickTime-Kapitelspuren werden in die Datei geschrieben. Wenn diese Option eingestellt ist, werden nur die
Die QuickTime-Kapitelspur wird geschrieben. Nero-Kapitel können zu Fehlern führen, wenn die
Die Datei wird mit bestimmten Tagging-Programmen wie mp3Tag 2.61a und iTunes 11.3 erneut verarbeitet.
höchstwahrscheinlich sind auch andere Versionen betroffen.
-Movflags weglassen_tfhd_offset
Schreiben Sie keinen absoluten base_data_offset in tfhd-Atome. Dies vermeidet das Zusammenbinden von Fragmenten
auf absolute Byte-Positionen in der Datei/den Streams.
-Movflags default_base_moof
Ähnlich wie bei omit_tfhd_offset vermeidet dieses Flag das Schreiben des absoluten
base_data_offset-Feld in tfhd-Atomen, jedoch unter Verwendung des neuen default-base-is-
stattdessen eine Moof-Flagge. Diese Flagge ist neu von 14496-12:2012. Dadurch können Fragmente entstehen
unter bestimmten Umständen einfacher zu analysieren (Vermeidung der Positionierung von Trackfragmenten auf Basis).
Berechnungen am impliziten Ende des vorherigen Spurfragments).
Beispiel
Damit können Smooth Streaming-Inhalte in Echtzeit an einen Veröffentlichungspunkt auf IIS übertragen werden
muxer. Beispiel:
ffmpeg -re < > -movflags isml+frag_keyframe -f ismv http://server/publishingpoint.isml/Streams(Geber1)
Audible AAX
Audible AAX-Dateien sind verschlüsselte M4B-Dateien und können durch Angabe eines 4 . entschlüsselt werden
Byte-Aktivierungsgeheimnis.
ffmpeg -activation_bytes 1CEB00DA -i test.aax -vn -c:a Ausgabe.mp4 kopieren
mp3
Der MP3-Muxer schreibt einen rohen MP3-Stream mit den folgenden optionalen Funktionen:
· Ein ID3v2-Metadaten-Header am Anfang (standardmäßig aktiviert). Versionen 2.3 und 2.4
unterstützt werden, steuert die private Option "id3v2_version", welche verwendet wird (3 oder 4).
Wenn Sie „id3v2_version“ auf 0 setzen, wird der ID3v2-Header vollständig deaktiviert.
Der Muxer unterstützt das Schreiben angehängter Bilder (APIC-Frames) in den ID3v2-Header. Der
Bilder werden dem Muxer in Form eines Videostreams mit einem einzigen Paket zugeführt.
Es kann eine beliebige Anzahl dieser Streams geben, jeder entspricht einem einzelnen APIC-Frame.
Die Stream-Metadaten-Tags Titel und Kommentar Karte zu APIC Beschreibung und ein Bild tippe
bzw. Sehenhttp://id3.org/id3v2.4.0-frames> für erlaubte Bildtypen.
Beachten Sie, dass die APIC-Frames am Anfang geschrieben werden müssen, damit der Muxer puffert
die Audio-Frames, bis alle Bilder vorliegen. Es wird daher empfohlen, diese bereitzustellen
Laden Sie die Bilder so schnell wie möglich herunter, um eine übermäßige Pufferung zu vermeiden.
· Ein Xing/LAME-Frame direkt nach dem ID3v2-Header (falls vorhanden). Es ist standardmäßig aktiviert,
wird aber nur geschrieben, wenn die Ausgabe suchbar ist. Die private Option „write_xing“.
kann verwendet werden, um es zu deaktivieren. Der Rahmen enthält verschiedene Informationen, die nützlich sein können
an den Decoder, wie die Audiodauer oder die Encoderverzögerung.
· Ein Legacy-ID3v1-Tag am Ende der Datei (standardmäßig deaktiviert). Es kann aktiviert sein
mit der privaten Option "write_id3v1", aber da ihre Fähigkeiten sehr begrenzt sind, ist es
Verwendung wird nicht empfohlen.
Beispiele:
Schreiben Sie eine MP3-Datei mit einer ID3v2.3-Kopfzeile und einer ID3v1-Fußzeile:
ffmpeg -i INPUT -id3v2_version 3 -write_id3v1 1 aus.mp3
Um ein Bild an eine mp3-Datei anzuhängen, wählen Sie sowohl den Audio- als auch den Bildstream mit
"Karte":
ffmpeg -i input.mp3 -i cover.png -c kopieren -map 0 -map 1
-metadata:s:v title="Album-Cover" -metadata:s:v comment="Cover (Vorderseite)" out.mp3
Schreiben Sie eine "saubere" MP3 ohne zusätzliche Funktionen:
ffmpeg -i input.wav -write_xing 0 -id3v2_version 0 out.mp3
mpegs
MPEG-Transportstrom-Muxer.
Dieser Muxer implementiert ISO 13818-1 und ist Teil von ETSI EN 300 468.
Die anerkannten Metadateneinstellungen in mpegts Muxer sind "service_provider" und
"Dienstname". Wenn sie nicht festgelegt sind, ist die Standardeinstellung für "service_provider" "FFmpeg" und die
Standard für "service_name" ist "Service01".
Optionen
Die Muxer-Optionen sind:
-mpegts_original_network_id Anzahl
Legen Sie die original_network_id fest (Standard 0x0001). Dies ist eine eindeutige Kennung eines Netzwerks
im DVB-T. Seine Hauptverwendung liegt in der eindeutigen Identifizierung eines Dienstes durch den Pfad
Original_Network_ID, Transport_Stream_ID.
-mpegts_transport_stream_id Anzahl
Legen Sie die transport_stream_id fest (Standard 0x0001). Dies identifiziert einen Transponder in DVB.
-mpegts_service_id Anzahl
Legen Sie die service_id (Standard 0x0001) fest, die in DVB auch als Programm bezeichnet wird.
-mpegts_service_type Anzahl
Setzen Sie das Programm service_type (Standard Digitales Fernsehen), siehe unten eine Liste der vordefinierten
Werte.
-mpegts_pmt_start_pid Anzahl
Legen Sie die erste PID für PMT fest (Standard 0x1000, max. 0x1f00).
-mpegts_start_pid Anzahl
Legen Sie die erste PID für Datenpakete fest (Standard 0x0100, max. 0x0f00).
-mpegts_m2ts_mode Anzahl
Aktivieren Sie den m2ts-Modus, wenn er auf 1 gesetzt ist. Der Standardwert ist -1, wodurch der m2ts-Modus deaktiviert wird.
-Muxrate Anzahl
Stellen Sie eine konstante Muxrate ein (Standard-VBR).
-pcr_period nummer
Überschreiben Sie die Standard-PCR-Neuübertragungszeit (Standard 20 ms), wird ignoriert, wenn variabel
muxrate ausgewählt ist.
pat_periode Anzahl
Maximale Zeit in Sekunden zwischen PAT/PMT-Tabellen.
sdt_period Anzahl
Maximale Zeit in Sekunden zwischen SDT-Tabellen.
-pes_payload_size Anzahl
Legen Sie die minimale PES-Paketnutzlast in Byte fest.
-mpegts_flags Fahnen
Setzen Sie Flags (siehe unten).
-mpegts_copyts Anzahl
Behalten Sie die ursprünglichen Zeitstempel bei, wenn der Wert auf 1 gesetzt ist. Der Standardwert ist -1, was dazu führt, dass
beim Verschieben von Zeitstempeln, sodass sie bei 0 beginnen.
-tables_version Anzahl
Stellen Sie die PAT-, PMT- und SDT-Version ein (Standard 0, gültige Werte sind von 0 bis einschließlich 31).
Mit dieser Option können Sie die Stream-Struktur aktualisieren, damit der Standardverbraucher sie erkennen kann
Veränderung. Öffnen Sie dazu die Ausgabe AVFormatContext (bei API-Nutzung) erneut oder starten Sie sie neu
ffmpeg-Instanz, zyklisch ändernder Wert von tables_version:
ffmpeg -i source1.ts -codec copy -f mpegts -tables_version 0 udp://1.1.1.1:1111
ffmpeg -i source2.ts -codec copy -f mpegts -tables_version 1 udp://1.1.1.1:1111
...
ffmpeg -i source3.ts -codec copy -f mpegts -tables_version 31 udp://1.1.1.1:1111
ffmpeg -i source1.ts -codec copy -f mpegts -tables_version 0 udp://1.1.1.1:1111
ffmpeg -i source2.ts -codec copy -f mpegts -tables_version 1 udp://1.1.1.1:1111
...
Die Option mpegts_service_type akzeptiert die folgenden Werte:
Hex_Wert
Jeder hexadezimale Wert zwischen 0x01 und 0xff, wie in ETSI 300 468 definiert.
Digitales Fernsehen
Digitaler TV-Dienst.
digitales Radio
Digitaler Radiodienst.
Videotext
Teletext-Dienst.
advanced_codec_digital_radio
Erweiterter Codec-Digitalradio-Dienst.
mpeg2_digital_hdtv
MPEG2 Digitaler HDTV-Dienst.
advanced_codec_digital_sdtv
Erweiterter Codec-Digital-SDTV-Dienst.
advanced_codec_digital_hdtv
Erweiterter Codec-Digital-HDTV-Dienst.
Die Option mpegts_flags kann einen Satz solcher Flags annehmen:
resend_headers
Senden Sie PAT/PMT erneut, bevor Sie das nächste Paket schreiben.
lat
Verwenden Sie die LATM-Paketierung für AAC.
pat_pmt_at_frames
Senden Sie PAT und PMT bei jedem Videobild erneut aus.
Beispiel
ffmpeg -i Datei.mpg -c kopieren \
-mpegts_original_network_id 0x1122 \
-mpegts_transport_stream_id 0x3344 \
-mpegts_service_id 0x5566 \
-mpegts_pmt_start_pid 0x1500 \
-mpegts_start_pid 0x150 \
-metadata service_provider="Einige Anbieter" \
-metadata service_name="Einige Kanäle" \
-y aus.ts
mxf, mxf_d10
MXF-Muxer.
Optionen
Die Muxer-Optionen sind:
store_user_comments bool
Legen Sie fest, ob Benutzerkommentare gespeichert werden sollen, falls verfügbar oder nie. IRT D-10 erlaubt nicht
Benutzerkommentare. Standardmäßig werden sie daher für mxf geschrieben, nicht jedoch für mxf_d10
null
Null-Muxer.
Dieser Muxer generiert keine Ausgabedatei, er ist hauptsächlich zum Testen oder zum Testen nützlich
Benchmarking-Zwecke.
Zum Beispiel zum Benchmarken der Dekodierung mit ffmpeg Sie können den Befehl verwenden:
ffmpeg -benchmark -i INPUT -f null out.null
Beachten Sie, dass der obige Befehl die aus.null Datei, aber unter Angabe der
Ausgabedatei wird von der ffmpeg Syntax.
Alternativ können Sie den Befehl schreiben als:
ffmpeg -benchmark -i EINGANG -f null -
Nuss
-Synchronisationspunkte Fahnen
Ändern Sie die Syncpoint-Nutzung in Nut:
Standard - normal geringer Overhead auf der Suche nach Aids.
keine do nicht - Synchronisationspunkte at alle, Reduzierung oben aber Herstellung Strom
nicht suchbar;
Die Verwendung dieser Option wird nicht empfohlen, da die resultierenden Dateien sehr beschädigt sind
sensibel und suchend ist nicht möglich. Auch im Allgemeinen der Overhead von
Syncpoints ist vernachlässigbar. Hinweis: -C 0 kann zum Deaktivieren verwendet werden
alle wachsenden Datentabellen, die es ermöglichen, endlose Streams mit begrenztem Speicher zu muxen
und ohne diese Nachteile.
Zeitstempel erweitern Synchronisationspunkt mit a Wanduhr Feld.
Die keine und Zeitstempel Flaggen sind experimentell.
-write_index bool
Index am Ende schreiben, standardmäßig wird ein Index geschrieben.
ffmpeg -i INPUT -f_strict experimentell -syncpoints keine - | Prozessor
ogg
Ogg-Container-Muxer.
-page_duration Dauer
Bevorzugte Seitendauer in Mikrosekunden. Der Muxer versucht, Seiten zu erstellen, die
sind ungefähr Dauer Mikrosekunden lang. Dies ermöglicht dem Benutzer, Kompromisse einzugehen
zwischen Suchgranularität und Container-Overhead. Der Standardwert ist 1 Sekunde. Ein Wert von 0
füllt alle Segmente und macht die Seiten so groß wie möglich. Ein Wert von 1 wird
Verwenden Sie in den meisten Situationen effektiv 1 Paket pro Seite, was eine kleine Suchgranularität ergibt
auf Kosten des zusätzlichen Container-Overheads.
-serial_offset Wert
Seriennummer, von der aus die Seriennummer des Streams festgelegt werden soll. Stellen Sie es auf andere ein und
ausreichend große Werte sorgen dafür, dass die erzeugten ogg-Dateien sicher verkettet werden können.
Segment, stream_segment, Segment
Grundlegender Stream-Segmentierer.
Dieser Muxer gibt Streams in eine Reihe separater Dateien mit nahezu fester Dauer aus. Ausgang
Das Dateinamenmuster kann auf ähnliche Weise wie festgelegt werden image2, oder mit "strftime"
Vorlage, wenn die strftime Option ist aktiviert.
"stream_segment" ist eine Variante des Muxers, der zum Schreiben in Streaming-Ausgabeformate verwendet wird, dh
die keine globalen Header erfordern und für die Ausgabe z. B. nach MPEG empfohlen werden
Transportstromsegmente. „ssegment“ ist ein kürzerer Alias für „stream_segment“.
Jedes Segment beginnt mit einem Keyframe des ausgewählten Referenzstreams, der gesetzt wird
durch das Referenzstrom .
Beachten Sie, dass Sie, wenn Sie eine genaue Aufteilung für eine Videodatei wünschen, den Eingabeschlüssel
Frames entsprechen genau den Teilungszeiten, die vom Segmentierer oder vom Segment erwartet werden
Muxer startet das neue Segment mit dem Schlüsselbild, das als nächstes nach dem angegebenen Start gefunden wurde
Zeit.
Der Segment-Muxer funktioniert am besten mit einem einzelnen Video mit konstanter Bildrate.
Optional kann eine Liste der erstellten Segmente generiert werden, indem die Option gesetzt wird
segment_liste. Der Listentyp wird durch die segment_list_type Möglichkeit. Der Eintritt
Dateinamen in der Segmentliste werden standardmäßig auf den Basisnamen des entsprechenden
Segmentdateien.
Siehe auch die hls Muxer, der eine spezifischere Implementierung für HLS bereitstellt
Segmentierung.
Optionen
Der Segment-Muxer unterstützt die folgenden Optionen:
Referenzstrom Bezeichner
Legen Sie den Referenzstream fest, wie durch die Zeichenfolge angegeben Bezeichner. Wenn Bezeichner eingestellt ist
auf "auto" wird die Referenz automatisch gewählt. Sonst muss es ein Stream sein
specifier (siehe das Kapitel ``Stream specifiers'' im ffmpeg-Handbuch), der spezifiziert
der Referenzstrom. Der Standardwert ist "auto".
segment_format Format
Überschreiben Sie das innere Containerformat. Standardmäßig wird es anhand des Dateinamens erraten
Erweiterung.
segment_format_options Optionen_Liste
Legen Sie Ausgabeformatoptionen mithilfe einer :-getrennten Liste von Schlüssel=Wert-Parametern fest. Werte
das das Sonderzeichen ":" enthält, muss mit Escapezeichen versehen werden.
segment_liste Name
Generiere auch eine Listendatei namens Name. Wenn nicht angegeben, wird keine Listendatei generiert.
segment_list_flags Fahnen
Setzen Sie Flags, die sich auf die Generierung von Segmentlisten auswirken.
Es unterstützt derzeit die folgenden Flags:
Cache-Speicher
Caching zulassen (betrifft nur M3U8-Listendateien).
leben
Ermöglichen Sie eine live-freundliche Dateigenerierung.
segment_list_size Größe
Aktualisieren Sie die Listendatei, sodass sie höchstens enthält Größe Segmente. Wenn 0 die Listendatei
enthält alle Segmente. Der Standardwert ist 0.
segment_list_entry_prefix Präfix
Vorbereiten Präfix zu jedem Eintrag. Nützlich, um absolute Pfade zu generieren. Standardmäßig kein Präfix
wird angewandt.
segment_list_type tippe
Wählen Sie das Listenformat aus.
Folgende Werte werden erkannt:
Wohnung
Generieren Sie eine flache Liste für die erstellten Segmente, ein Segment pro Zeile.
csv-, ext
Erstellen Sie eine Liste für die erstellten Segmente, ein Segment pro Zeile, wobei jede Zeile übereinstimmt
das Format (durch Kommas getrennte Werte):
, ,
segment_dateiname ist der Name der vom Muxer erzeugten Ausgabedatei gemäß
nach dem bereitgestellten Muster. CSV-Escape-Funktion (gemäß RFC4180) wird angewendet, wenn
erforderlich.
segment_start_time und segment_end_time Geben Sie die Start- und Endzeit des Segments an
in Sekunden ausgedrückt.
Eine Listendatei mit dem Suffix „.csv“ oder „.ext“ wählt dieses Format automatisch aus.
ext wird abgelehnt oder csv.
ffkonkat
Generieren Sie eine ffconcat-Datei für die erstellten Segmente. Die resultierende Datei kann gelesen werden
mit dem FFmpeg concat Demuxer.
Eine Listendatei mit dem Suffix „.ffcat“ oder „.ffconcat“ wählt dieses Format automatisch aus.
m3u8
Generieren Sie eine erweiterte M3U8-Datei, Version 3, konform mit
<http://tools.ietf.org/id/draft-pantos-http-live-streaming>.
Eine Listendatei mit dem Suffix „.m3u8“ wählt dieses Format automatisch aus.
Wenn nicht angegeben, wird der Typ aus dem Listendateinamensuffix erraten.
segment_time Zeit
Segmentdauer auf setzen Zeit, muss der Wert eine Dauerangabe sein. Standard
Wert ist "2". Siehe auch die segment_times .
Beachten Sie, dass die Aufteilung möglicherweise nicht genau ist, es sei denn, Sie erzwingen den Referenz-Stream-Schlüssel-
Rahmen zur angegebenen Zeit. Siehe die Einführung und die Beispiele unten.
segment_atclocktime 1 | 0
Bei Einstellung „1“ erfolgt die Aufteilung in regelmäßigen Zeitintervallen ab 00:00 Uhr. Der
Zeit Wert angegeben in segment_time dient zur Einstellung der Spaltlänge
Intervall.
Zum Beispiel mit segment_time auf "900" eingestellt ermöglicht dies das Erstellen von Dateien unter
12:00 Uhr, 12:15, 12:30 usw.
Der Standardwert ist "0".
segment_time_delta Delta
Geben Sie die Genauigkeitszeit bei der Auswahl der Startzeit für ein Segment an, ausgedrückt als a
Angabe der Dauer. Der Standardwert ist "0".
Wenn Delta angegeben ist, startet ein Schlüsselbild ein neues Segment, wenn sein PTS die Anforderungen erfüllt
Beziehung:
PTS >= start_time - time_delta
Diese Option ist nützlich, wenn Sie Videoinhalte aufteilen, die immer nach GOP aufgeteilt werden
Grenzen, falls ein Keyframe kurz vor der angegebenen Split-Zeit gefunden wird.
Kann insbesondere in Kombination mit dem ffmpeg zu erhalten force_key_framesdem „Vermischten Geschmack“. Seine
Keyframe-Zeiten angegeben durch force_key_frames möglicherweise nicht genau eingestellt, weil
Rundungsprobleme, mit der Folge, dass eine Schlüsselbildzeit kurz vor dem
die angegebene Zeit. Für Videos mit konstanter Bildrate ein Wert von 1/(2*Bildrate) sollte
Beheben Sie die Worst-Case-Nichtübereinstimmung zwischen der angegebenen Zeit und der von eingestellten Zeit
force_key_frames.
segment_times mal
Geben Sie eine Liste von Splitpunkten an. mal enthält eine Liste der durch Kommas getrennten Dauer
Spezifikationen, in aufsteigender Reihenfolge. Siehe auch die segment_time .
segment_frames Rahmen
Geben Sie eine Liste mit geteilten Videobildnummern an. Rahmen enthält eine durch Kommas getrennte Liste
ganze Zahlen in aufsteigender Reihenfolge.
Diese Option legt fest, dass ein neues Segment immer dann gestartet wird, wenn ein Referenz-Stream-Keyframe
gefunden und die fortlaufende Nummer (beginnend mit 0) des Frames ist größer oder gleich
der nächste Wert in der Liste.
segment_wrap begrenzen
Segmentindex umbrechen, sobald er erreicht ist begrenzen.
segment_start_number Anzahl
Legen Sie die Sequenznummer des ersten Segments fest. Standardmäßig auf 0.
strftime 1 | 0
Verwenden Sie die Funktion "strftime", um den Namen der neu zu schreibenden Segmente zu definieren. Wenn das
ausgewählt ist, muss der Ausgabesegmentname eine „strftime“-Funktionsvorlage enthalten.
Der Standardwert ist 0.
break_non_keyframes 1 | 0
Wenn diese Option aktiviert ist, lassen Sie zu, dass Segmente auf anderen Frames als Keyframes beginnen. Das verbessert sich
Verhalten bei einigen Playern, wenn die Zeit zwischen Keyframes inkonsistent ist, kann aber zu Problemen führen
bei anderen schlimmer und kann beim Suchen einige Merkwürdigkeiten verursachen. Standardmäßig auf 0.
reset_timestamps 1 | 0
Setzen Sie die Zeitstempel zu Beginn jedes Segments zurück, sodass jedes Segment mit beginnt
Zeitstempel nahe Null. Es soll die Wiedergabe der generierten Segmente erleichtern. Dürfen
funktioniert nicht mit einigen Kombinationen von Muxern/Codecs. Es ist standardmäßig auf 0 gesetzt.
initial_offset Offset
Geben Sie den Zeitstempel-Offset an, der auf die Zeitstempel der Ausgabepakete angewendet werden soll. Das Argument muss
eine Zeitdauerangabe sein, und der Standardwert ist 0.
Beispiele
· Remuxen Sie den Inhalt der Datei in.mkv zu einer Liste von Segmenten out-000.nut, out-001.nutUsw.
und schreibe die Liste der generierten Segmente nach aus.liste:
ffmpeg -i in.mkv -codec copy -map 0 -f segment -segment_list out.list out%03d.nut
· Segment-Input- und Set-Output-Format-Optionen für die Ausgabesegmente:
ffmpeg -i in.mkv -f segment -segment_time 10 -segment_format_options movflags=+faststart out%03d.mp4
· Segmentieren Sie die Eingabedatei gemäß den von der segment_times
Option:
ffmpeg -i in.mkv -codec kopieren -map 0 -f segment -segment_list out.csv -segment_times 1,2,3,5,8,13,21 out%03d.nut
· Verwenden Sie die ffmpeg force_key_frames Option, um Keyframes in der Eingabe zu erzwingen
angegebener Ort, zusammen mit der Segmentoption segment_time_delta Rechenschaft ablegen
mögliche Rundungen beim Einstellen von Keyframe-Zeiten.
ffmpeg -i in.mkv -force_key_frames 1,2,3,5,8,13,21 -codec:v mpeg4 -codec:a pcm_s16le -map 0 \
-f segment -segment_list out.csv -segment_times 1,2,3,5,8,13,21 -segment_time_delta 0.05 out%03d.nut
Um Schlüsselbilder in der Eingabedatei zu erzwingen, ist eine Transkodierung erforderlich.
· Segmentieren Sie die Eingabedatei, indem Sie die Eingabedatei entsprechend den Bildnummern aufteilen
Reihenfolge angegeben mit dem segment_frames Option:
ffmpeg -i in.mkv -codec copy -map 0 -f segment -segment_list out.csv -segment_frames 100,200,300,500,800 out%03d.nut
· Konvertieren Sie die in.mkv zu TS-Segmenten mit den Encodern "libx264" und "libfaac":
ffmpeg -i in.mkv -map 0 -codec:v libx264 -codec:a libfaac -f ssegment -segment_list out.list out%03d.ts
· Segmentieren Sie die Eingabedatei und erstellen Sie eine M3U8-Live-Wiedergabeliste (kann als Live-HLS verwendet werden)
Quelle):
ffmpeg -re -i in.mkv -codec kopieren -map 0 -f Segment -segment_list playlist.m3u8 \
-segment_list_flags +live -segment_time 10 out%03d.mkv
reibungsloses Streaming
Smooth Streaming Muxer generiert eine Reihe von Dateien (Manifest, Chunks), die für die Bereitstellung geeignet sind
mit herkömmlichem Webserver.
Fenstergröße
Geben Sie die Anzahl der Fragmente an, die im Manifest aufbewahrt werden. Standard 0 (alle behalten).
extra_window_size
Geben Sie die Anzahl der Fragmente an, die außerhalb des Manifests aufbewahrt werden, bevor Sie sie aus . entfernen
Scheibe. Vorgabe 5.
lookahead_count
Geben Sie die Anzahl der Lookahead-Fragmente an. Vorgabe 2.
min_frag_duration
Geben Sie die minimale Fragmentdauer (in Mikrosekunden) an. Standard 5000000.
Remove_at_exit
Geben Sie an, ob alle Fragmente entfernt werden sollen, wenn Sie fertig sind. Standard 0 (nicht entfernen).
Abschlag
Der Tee Muxer kann verwendet werden, um die gleichen Daten in mehrere Dateien zu schreiben oder jede andere Art von
muxer. Es kann beispielsweise verwendet werden, um ein Video sowohl ins Netzwerk zu streamen als auch zu speichern
Festplatte gleichzeitig.
Es unterscheidet sich von der Angabe mehrerer Ausgänge an die ffmpeg Befehlszeilentool, weil
die Audio- und Videodaten werden mit dem Tee-Muxer nur einmal kodiert; Kodierung kann ein sein
sehr teurer Prozess. Dies ist nicht sinnvoll, wenn die libavformat-API direkt verwendet wird, weil
es ist dann möglich, die gleichen Pakete direkt mehreren Muxern zuzuführen.
Die Slave-Ausgänge werden im Dateinamen angegeben, der dem Muxer gegeben wird, getrennt durch „|“. Wenn
Jeder der Slave-Namen enthält das '|' Trennzeichen, führende oder nachgestellte Leerzeichen oder beliebige
Sonderzeichen, es muss mit Escapezeichen versehen werden (siehe "Zitieren und Flucht" Abschnitt in
ffmpeg-utils(1) manuell).
Muxer-Optionen können für jeden Slave angegeben werden, indem ihnen eine Liste von . vorangestellt wird Haupt=Wert
Paare getrennt durch „:“, in eckigen Klammern. Wenn die Optionswerte ein Sonderzeichen enthalten
Zeichen oder das Trennzeichen ':' müssen sie mit Escapezeichen versehen werden; Beachten Sie, dass dies eine zweite Ebene ist
entkommen.
Außerdem werden folgende Sonderoptionen anerkannt:
f Geben Sie den Formatnamen an. Nützlich, wenn es anhand des Suffixes des Ausgabenamens nicht erraten werden kann.
bsfs[/spec]
Geben Sie eine Liste von Bitstream-Filtern an, die auf die angegebene Ausgabe angewendet werden sollen.
Es ist möglich, anzugeben, auf welche Streams ein bestimmter Bitstream-Filter angewendet wird
Anhängen eines Stream-Bezeichners an die Option, getrennt durch "/". spec muss ein Stream sein
Bezeichner (siehe Format Strom Bezeichner). Wenn der Streamspezifizierer nicht angegeben ist,
die Bitstream-Filter werden auf alle Streams in der Ausgabe angewendet.
Es können mehrere Bitstromfilter angegeben werden, getrennt durch ",".
wählen
Wählen Sie die Streams aus, die dem Slave-Ausgang zugeordnet werden sollen, angegeben durch einen Stream
Spezifizierer. Wenn nicht angegeben, werden standardmäßig alle Eingabestreams verwendet.
Beispiele
· Kodieren Sie etwas und archivieren Sie es in einer WebM-Datei und streamen Sie es als MPEG-TS über UDP
(die Streams müssen explizit zugeordnet werden):
ffmpeg -i ... -c:v libx264 -c:a mp2 -f tee -map 0:v -map 0:a
"archive-20121107.mkv|[f=mpegts]udp://10.0.1.255:1234/"
· Verwenden ffmpeg um die Eingabe zu kodieren und die Ausgabe an drei verschiedene Ziele zu senden.
Der Bitstream-Filter "dump_extra" wird verwendet, um allen
Gibt Video-Keyframes-Pakete aus, wie vom MPEG-TS-Format gefordert. Die Auswahloption
wird angewendet auf aus.aac damit es nur Audiopakete enthält.
ffmpeg -i ... -map 0 -flags +global_header -c:v libx264 -c:a aac -strict experimentell
-f tee „[bsfs/v=dump_extra]out.ts|[movflags=+faststart]out.mp4|[select=a]out.aac“
· Wie unten, aber wählen Sie nur Stream "a:1" für die Audioausgabe. Beachten Sie, dass eine zweite Ebene
Es muss ein Escaping durchgeführt werden, da ":" ein Sonderzeichen ist, das verwendet wird, um Optionen zu trennen.
ffmpeg -i ... -map 0 -flags +global_header -c:v libx264 -c:a aac -strict experimentell
-f tee "[bsfs/v=dump_extra]out.ts|[movflags=+faststart]out.mp4|[select=\'a:1\']out.aac"
Hinweis: Einige Codecs benötigen möglicherweise je nach Ausgabeformat unterschiedliche Optionen; das Auto-
Die Erkennung dieses Problems kann mit dem Tee-Muxer nicht funktionieren. Das Hauptbeispiel ist das global_header
Flagge.
webm_dash_manifest
WebM DASH Manifest-Muxer.
Dieser Muxer implementiert die WebM-DASH-Manifest-Spezifikation, um das DASH-Manifest zu generieren
XML. Es unterstützt auch die Manifestgenerierung für DASH-Livestreams.
Für weitere Informationen siehe:
· WebM DASH-Spezifikation:
<https://sites.google.com/a/webmproject.org/wiki/adaptive-streaming/webm-dash-specification>
· ISO DASH-Spezifikation:
<http://standards.iso.org/ittf/PubliclyAvailableStandards/c065274_ISO_IEC_23009-1_2014.zip>
Optionen
Dieser Muxer unterstützt die folgenden Optionen:
Anpassungssätze
Diese Option hat die folgende Syntax: „id=x,streams=a,b,c id=y,streams=d,e“, wobei x
und y die eindeutigen Kennungen der Anpassungssätze sind und a,b,c,d und e die
Indizes der entsprechenden Audio- und Videostreams. Beliebig viele Adaptionssätze
können mit dieser Option hinzugefügt werden.
leben
Setzen Sie dies auf 1, um ein Live-Stream-DASH-Manifest zu erstellen. Standard: 0.
chunk_start_index
Startindex des ersten Chunks. Das geht in die Startnummer Attribut des
Segmentvorlage Element im Manifest. Standard: 0.
chunk_duration_ms
Dauer jedes Chunks in Millisekunden. Das geht in die Dauer Attribut des
Segmentvorlage Element im Manifest. Standard: 1000.
utc_timing_url
URL der Seite, die den UTC-Zeitstempel im ISO-Format zurückgibt. Das geht in die
Wert Attribut des UTC-Zeit Element im Manifest. Standard: Keine.
time_shift_buffer_ Depth
Kleinster Zeitverschiebungspuffer (in Sekunden), für den eine Darstellung garantiert ist
zu Verfügung stehen. Das geht in die timeShiftBufferDepth Attribut des MPD
Element. Standard: 60.
minimaler_Update_Zeitraum
Mindestaktualisierungszeit (in Sekunden) des Manifests. Das geht in die
MinimumUpdatePeriode Attribut des MPD Element. Standard: 0.
Beispiel
ffmpeg -f webm_dash_manifest -i video1.webm \
-f webm_dash_manifest -i video2.webm \
-f webm_dash_manifest -i audio1.webm \
-f webm_dash_manifest -i audio2.webm \
-Karte 0 -Karte 1 -Karte 2 -Karte 3 \
-c kopieren \
-f webm_dash_manifest \
-adaptation_sets "id=0,streams=0,1 id=1,streams=2,3" \
manifest.xml
webm_chunk
WebM Live-Chunk-Muxer.
Dieser Muxer schreibt WebM-Header und -Chunks als separate Dateien, die von konsumiert werden können
Clients, die WebM-Live-Streams über DASH unterstützen.
Optionen
Dieser Muxer unterstützt die folgenden Optionen:
chunk_start_index
Index des ersten Chunks (standardmäßig 0).
Kopfzeile
Dateiname des Headers, in den die Initialisierungsdaten geschrieben werden.
audio_chunk_duration
Dauer jedes Audio-Chunks in Millisekunden (standardmäßig 5000).
Beispiel
ffmpeg -f v4l2 -i /dev/video0 \
-f alsa -i hw:0 \
-Karte 0:0 \
-c:vlibvpx-vp9 \
-s 640x360 -keyint_min 30 -g 30 \
-f webm_chunk \
-header webm_live_video_360.hdr \
-chunk_start_index 1 \
webm_live_video_360_%d.chk \
-Karte 1:0 \
-c:a libvorbis \
-b:a 128k \
-f webm_chunk \
-header webm_live_audio_128.hdr \
-chunk_start_index 1 \
-audio_chunk_duration 1000 \
webm_live_audio_128_%d.chk
METADATEN
FFmpeg ist in der Lage, Metadaten aus Mediendateien in einen einfachen UTF-8-codierten INI-ähnlichen Text zu übertragen
Datei und laden Sie sie dann mit dem Metadaten-Muxer/Demuxer zurück.
Das Dateiformat ist wie folgt:
1. Eine Datei besteht aus einem Header und einer Reihe von Metadaten-Tags, die jeweils in Abschnitte unterteilt sind
auf eigener Linie.
2. Der Header ist a ;FFMETADATEN string, gefolgt von einer Versionsnummer (jetzt 1).
3. Metadaten-Tags haben die Form Schlüssel=Wert
4. Unmittelbar nach dem Header folgen globale Metadaten
5. Nach globalen Metadaten kann es Abschnitte mit Metadaten pro Stream/Kapitel geben.
6. Ein Abschnitt beginnt mit dem Abschnittsnamen in Großbuchstaben (zB STREAM oder KAPITEL) in
Klammern ([, ]) und endet mit dem nächsten Abschnitt oder dem Ende der Datei.
7. Am Anfang eines Kapitelabschnitts kann es eine optionale Zeitbasis geben, die verwendet werden kann für
Start-/Endwerte. Es muss in Form sein ZEITBASIS=num/am, Wobei num und am sind ganze Zahlen.
Wenn die Zeitbasis fehlt, werden Start-/Endzeiten in Millisekunden angenommen.
Als nächstes muss ein Kapitelabschnitt die Anfangs- und Endzeiten des Kapitels in Form enthalten START =num,
ENDE=num, Wobei num ist eine positive ganze Zahl.
8. Leerzeilen und Zeilen, die mit beginnen ; or # werden ignoriert.
9. Metadatenschlüssel oder Werte mit Sonderzeichen (=, ;, #, \ und ein Zeilenumbruch) muss
mit einem Backslash entkommen \.
10. Beachten Sie, dass Leerzeichen in Metadaten (z. B. foo = Bar) gilt als Teil der
Tag (im obigen Beispiel ist der Schlüssel foo , Wert ist
Bar).
Eine ffmetadata-Datei könnte so aussehen:
;FFMETADATEN1
title=Fahrrad\\Schuppen
;das ist ein Kommentar
artist=FFmpeg-Troll-Team
[KAPITEL]
ZEITBASIS=1/1000
START=0
#Kapitel endet um 0:01:00
ENDE=60000
title=Kapitel \#1
[STROM]
Titel=mehrere\
Linie
Mit dem ffmetadata Muxer und Demuxer ist es möglich, Metadaten aus einer Eingabe zu extrahieren
Datei in eine ffmetadata-Datei und transkodieren Sie die Datei dann mit dem in eine Ausgabedatei
bearbeitete ffmetadata-Datei.
Extrahieren einer ffmetadata-Datei mit ffmpeg geht wie folgt:
ffmpeg -i INPUT -f ffmetadata FFMETADATAFILE
Das erneute Einfügen von bearbeiteten Metadateninformationen aus der FFMETADATAFILE-Datei kann wie folgt erfolgen:
ffmpeg -i INPUT -i FFMETADATAFILE -map_metadata 1 -codec copy OUTPUT
PROTOKOLLE
Protokolle sind konfigurierte Elemente in FFmpeg, die den Zugriff auf Ressourcen ermöglichen, die
spezielle Protokolle.
Wenn Sie Ihren FFmpeg-Build konfigurieren, sind alle unterstützten Protokolle standardmäßig aktiviert.
Sie können alle verfügbaren mit der Konfigurationsoption "--list-protocols" auflisten.
Sie können alle Protokolle mit der Konfigurationsoption "--disable-protocols" deaktivieren und
Aktivieren Sie selektiv ein Protokoll mit der Option "--enable-protocol=PROTOKOLL", oder du kannst
deaktivieren Sie ein bestimmtes Protokoll mit der Option "--disable-protocol=PROTOKOLL".
Die Option "-protocols" des ff*-Tools zeigt die Liste der unterstützten Protokolle an.
Es folgt eine Beschreibung der derzeit verfügbaren Protokolle.
async
Asynchroner Wrapper zum Füllen von Daten für den Eingabestrom.
Füllen Sie Daten in einen Hintergrund-Thread, um die E/A-Operation vom Demux-Thread zu entkoppeln.
asynchron:
asynchron:http://host/resource
async:cache:http://host/resource
Blu-Ray
BluRay-Wiedergabeliste lesen.
Die akzeptierten Optionen sind:
Winkel
BluRay-Winkel
Kapitel
Kapitel starten (1...N)
Playliste
Playlist zum Lesen (BDMV/PLAYLIST/?????.mpls)
Beispiele:
Lesen Sie die längste Playlist von BluRay, die in /mnt/bluray eingebunden ist:
Bluray:/mnt/Bluray
Lesen Sie Winkel 2 von Playlist 4 von BluRay eingehängt auf /mnt/bluray, beginnen Sie mit Kapitel 2:
-Playlist 4 -Winkel 2 -Kapitel 2 Bluray:/mnt/bluray
Cache-Speicher
Caching-Wrapper für den Eingabestream.
Zwischenspeichern des Eingabestreams in einer temporären Datei. Es bringt Suchfunktionen in Live-Streams.
Zwischenspeicher:
concat
Physisches Verkettungsprotokoll.
Lesen und durchsuchen Sie viele Ressourcen nacheinander, als ob sie eine einzige Ressource wären.
Eine von diesem Protokoll akzeptierte URL hat die Syntax:
konkat: | |...|
woher URL1, URL2... URLN sind die URLs der zu verkettenden Ressource, jede einzelne
möglicherweise ein eindeutiges Protokoll angeben.
Zum Beispiel um eine Folge von Dateien zu lesen split1.mpeg, split2.mpeg, split3.mpeg mit ffplay
Verwenden Sie den Befehl:
ffplay concat:split1.mpeg\|split2.mpeg\|split3.mpeg
Beachten Sie, dass Sie möglicherweise das Zeichen "|" mit Escapezeichen versehen müssen. was für viele Muscheln besonders ist.
Krypto
AES-verschlüsseltes Stream-Leseprotokoll.
Die akzeptierten Optionen sind:
Haupt Legen Sie den Binärblock des AES-Entschlüsselungsschlüssels aus der angegebenen hexadezimalen Darstellung fest.
iv Legen Sie den Binärblock des AES-Entschlüsselungsinitialisierungsvektors von der angegebenen Hexadezimalzahl fest
Darstellung.
Akzeptierte URL-Formate:
Krypto:
Krypto+
die Datenerfassung
Daten in-line im URI. Sehenhttp://en.wikipedia.org/wiki/Data_URI_scheme>.
Um beispielsweise eine GIF-Datei zu konvertieren, die inline mit ffmpeg:
ffmpeg -i "" smiley.png
Datei
Dateizugriffsprotokoll.
Aus einer Datei lesen oder in eine Datei schreiben.
Eine Datei-URL kann die Form haben:
Datei:
woher Dateinamen ist der Pfad der zu lesenden Datei.
Eine URL ohne Protokollpräfix wird als Datei-URL angenommen. Es hängt davon ab
der Build, eine URL, die wie ein Windows-Pfad mit dem Laufwerksbuchstaben am Anfang aussieht
wird auch als Datei-URL angenommen (normalerweise nicht der Fall in Builds für Unix-like
Systeme).
Zum Beispiel um aus einer Datei zu lesen Eingabe.mpeg mit ffmpeg Verwenden Sie den Befehl:
ffmpeg -i Datei:input.mpeg output.mpeg
Dieses Protokoll akzeptiert die folgenden Optionen:
abschneiden
Vorhandene Dateien beim Schreiben abschneiden, wenn auf 1 gesetzt. Ein Wert von 0 verhindert das Abschneiden.
Der Standardwert ist 1.
Block Größe
Legen Sie die maximale Blockgröße für die E/A-Operation in Byte fest. Der Standardwert ist "INT_MAX", was
führt dazu, dass die angeforderte Blockgröße nicht begrenzt wird. Setzen Sie diesen Wert angemessen niedrig
Verbessert die Reaktionszeit von Benutzerbeendigungsanfragen, was für langsame Dateien von Vorteil ist
Mittel.
ftp
FTP (Dateiübertragungsprotokoll).
Lesen von oder Schreiben auf Remote-Ressourcen mithilfe des FTP-Protokolls.
Folgende Syntax ist erforderlich.
ftp://[Benutzer[:Passwort]@]Server[:Port]/Pfad/zu/Remote/Ressource.mpeg
Dieses Protokoll akzeptiert die folgenden Optionen.
Timeout
Legen Sie das Timeout in Mikrosekunden für Socket-I/O-Operationen fest, die vom zugrunde liegenden Low-Level verwendet werden
Betrieb. Standardmäßig ist es auf -1 gesetzt, was bedeutet, dass das Timeout nicht angegeben ist.
ftp-anonymes-passwort
Passwort, das bei der Anmeldung als anonymer Benutzer verwendet wird. Normalerweise sollte eine E-Mail-Adresse lauten
benutzt.
ftp-write-suchbar
Kontrollieren Sie die Suchfähigkeit der Verbindung während der Codierung. Wenn auf 1 gesetzt, ist die Ressource
soll suchbar sein, wenn es auf 0 gesetzt ist, wird angenommen, dass es nicht suchbar ist. Standardwert
ist 0.
HINWEIS: Das Protokoll kann als Ausgabe verwendet werden, es wird jedoch empfohlen, dies nicht zu tun, es sei denn, es ist speziell
Sorgfalt verwendet wird (Tests, angepasste Serverkonfiguration etc.). Unterschiedliche FTP-Server verhalten sich
auf andere Weise während des Suchvorgangs. ff*-Tools können unvollständige Inhalte erzeugen aufgrund von
Serverbeschränkungen.
Ziesel
Gopher-Protokoll.
hls
Lesen Sie einen mit Apple HTTP Live Streaming kompatiblen segmentierten Stream als einheitlichen. Der M3U8
Playlists, die die Segmente beschreiben, können Remote-HTTP-Ressourcen oder lokale Dateien sein, auf die zugegriffen wird
unter Verwendung des Standarddateiprotokolls. Das verschachtelte Protokoll wird durch Angabe von "+deshalb"
nach dem hls-URI-Schemanamen, wobei deshalb ist entweder "Datei" oder "http".
hls+http://host/path/to/remote/resource.m3u8
hls+file://path/to/local/resource.m3u8
Von der Verwendung dieses Protokolls wird abgeraten - der hls-Demuxer sollte genauso gut funktionieren (wenn nicht,
bitte melden Sie die Probleme) und ist vollständiger. Um stattdessen den hls-Demuxer zu verwenden, einfach
Verwenden Sie die direkten URLs zu den m3u8-Dateien.
http
HTTP (Hypertext-Übertragungsprotokoll).
Dieses Protokoll akzeptiert die folgenden Optionen:
suchbar
Kontrollieren Sie die Suchfähigkeit der Verbindung. Wenn auf 1 gesetzt, soll die Ressource . sein
suchbar, wenn sie auf 0 gesetzt ist, wird angenommen, dass sie nicht suchbar ist, wenn sie auf -1 gesetzt ist, wird dies versucht
automatisch erkennen, wenn es durchsuchbar ist. Der Standardwert ist -1.
chunked_post
Wenn der Wert auf 1 gesetzt ist, verwenden Sie chunked Transfer-Encoding für Beiträge, der Standardwert ist 1.
content_type
Legen Sie einen bestimmten Inhaltstyp für die POST-Nachrichten fest.
Überschriften
Legen Sie benutzerdefinierte HTTP-Header fest, können Sie integrierte Standard-Header überschreiben. Der Wert muss a . sein
Zeichenfolge, die die Header codiert.
multiple_requests
Beständige Verbindungen verwenden, wenn auf 1 gesetzt, der Standardwert ist 0.
Post-Daten
Legen Sie benutzerdefinierte HTTP-Postdaten fest.
User-Agent
user_agent
Überschreiben Sie den User-Agent-Header. Wenn nicht angegeben, verwendet das Protokoll eine Zeichenfolge
Beschreibung des libavformat-Builds. ("Lavf/ ")
Timeout
Legen Sie das Timeout in Mikrosekunden für Socket-I/O-Operationen fest, die vom zugrunde liegenden Low-Level verwendet werden
Betrieb. Standardmäßig ist es auf -1 gesetzt, was bedeutet, dass das Timeout nicht angegeben ist.
Mime Typ
Exportieren Sie den MIME-Typ.
eisig Wenn auf 1 gesetzt, fordern Sie ICY (SHOUTcast)-Metadaten vom Server an. Wenn der Server unterstützt
Dazu müssen die Metadaten von der Anwendung durch Lesen der
icy_metadata_headers und eisiges_metadaten_paket Optionen. Der Standardwert ist 1.
icy_metadata_headers
Wenn der Server ICY-Metadaten unterstützt, enthält diese die ICY-spezifische HTTP-Antwort
Header, getrennt durch Newline-Zeichen.
eisiges_metadaten_paket
Wenn der Server ICY-Metadaten unterstützt und eisig auf 1 gesetzt wurde, enthält dies die letzten nicht-
vom Server gesendetes leeres Metadatenpaket. Es sollte in regelmäßigen Abständen von . abgefragt werden
Anwendungen, die an Mid-Stream-Metadaten-Updates interessiert sind.
Cookies
Legen Sie die Cookies fest, die bei zukünftigen Anfragen gesendet werden sollen. Das Format jedes Cookies ist gleich
als Wert eines Set-Cookie-HTTP-Antwortfelds. Mehrere Cookies können getrennt werden durch
ein Newline-Zeichen.
Offset
Stellen Sie den anfänglichen Byte-Offset ein.
end_offset
Versuchen Sie, die Anforderung auf Bytes vor diesem Offset zu beschränken.
Methode
Bei Verwendung als Clientoption legt sie die HTTP-Methode für die Anforderung fest.
Bei Verwendung als Serveroption legt sie die HTTP-Methode fest, die erwartet wird von
die Kunden). Wenn die erwartete und die empfangene HTTP-Methode nicht mit dem Client übereinstimmen
erhalten eine Bad Request-Antwort. Wenn nicht festgelegt, wird die HTTP-Methode nicht überprüft
jetzt. Dies wird in Zukunft durch die automatische Erkennung ersetzt.
hören
Wenn auf 1 gesetzt, wird der experimentelle HTTP-Server aktiviert. Dies kann verwendet werden, um Daten zu senden, wenn verwendet
als Ausgabeoption oder lesen Sie Daten von einem Client mit HTTP POST, wenn sie als Eingabe verwendet werden
Möglichkeit. Wenn auf 2 gesetzt, wird ein experimenteller Multi-Client-HTTP-Server aktiviert. Das ist noch nicht
in ffmpeg.c oder ffserver.c implementiert und darf daher nicht als Kommandozeile verwendet werden
.
# Serverseite (sendend):
ffmpeg -i somefile.ogg -c kopieren -listen 1 -f ogg http:// :
# Clientseite (empfangend):
ffmpeg -i http:// : -c kopiere eine Datei.ogg
# Client kann auch mit wget ausgeführt werden:
wget http:// : -O somefile.ogg
# Serverseite (empfangend):
ffmpeg -hören 1 -i http:// : -c kopiere eine Datei.ogg
# Clientseite (sendend):
ffmpeg -i somefile.ogg -chunked_post 0 -c kopieren -f ogg http:// :
# Client kann auch mit wget ausgeführt werden:
wget --post-file=somefile.ogg http:// :
HTTP Cookies
Einige HTTP-Anfragen werden abgelehnt, es sei denn, Cookie-Werte werden mit der Anfrage übergeben. Die
Cookies Option ermöglicht die Angabe dieser Cookies. Zumindest muss jeder Cookie
Geben Sie einen Wert zusammen mit einem Pfad und einer Domäne an. HTTP-Anfragen, die sowohl mit der Domäne übereinstimmen
und Pfad wird automatisch den Cookie-Wert in das HTTP-Cookie-Header-Feld einschließen.
Mehrere Cookies können durch einen Zeilenumbruch getrennt werden.
Die erforderliche Syntax zum Abspielen eines Streams, der ein Cookie angibt, ist:
ffplay -cookies "nlqptid=nltid=tsn; path=/; domain=somedomain.com;" http://somedomain.com/somestream.m3u8
Eiscast
Icecast-Protokoll (Stream zu Icecast-Servern)
Dieses Protokoll akzeptiert die folgenden Optionen:
Eisgenre
Legen Sie das Stream-Genre fest.
Eisname
Legen Sie den Streamnamen fest.
Eis_Beschreibung
Legen Sie die Stream-Beschreibung fest.
ice_url
Legen Sie die URL der Stream-Website fest.
ice_public
Legen Sie fest, ob der Stream öffentlich sein soll. Der Standardwert ist 0 (nicht öffentlich).
user_agent
Überschreiben Sie den User-Agent-Header. Wenn nicht angegeben, wird ein String der Form "Lavf/ "
werden verwendet.
Passwort
Legen Sie das Icecast-Mountpoint-Passwort fest.
content_type
Legen Sie den Stream-Inhaltstyp fest. Dies muss eingestellt werden, wenn es sich von Audio/mpeg unterscheidet.
Legacy_icecast
Dies ermöglicht die Unterstützung für Icecast-Versionen < 2.4.0, die HTTP PUT . nicht unterstützen
-Methode, sondern die SOURCE-Methode.
icecast://[ [: ]@] : /
mmst
MMS-Protokoll (Microsoft Media Server) über TCP.
mmsch
MMS-Protokoll (Microsoft Media Server) über HTTP.
Die erforderliche Syntax lautet:
mmsh:// [: ][/ ][/ ]
md5
MD5-Ausgabeprotokoll.
Berechnet den MD5-Hash der zu schreibenden Daten und schreibt ihn beim Schließen in die
designierte Ausgabe oder stdout, wenn keine angegeben ist. Es kann verwendet werden, um Muxer ohne zu testen
Schreiben einer tatsächlichen Datei.
Einige Beispiele folgen.
# Schreiben Sie den MD5-Hash der kodierten AVI-Datei in die Datei output.avi.md5.
ffmpeg -i input.flv -f avi -y md5:output.avi.md5
# Schreiben Sie den MD5-Hash der codierten AVI-Datei auf stdout.
ffmpeg -i input.flv -f avi -y md5:
Beachten Sie, dass einige Formate (normalerweise MOV) erfordern, dass das Ausgabeprotokoll durchsucht werden kann
wird mit dem MD5-Ausgabeprotokoll fehlschlagen.
Rohr
UNIX-Pipe-Zugriffsprotokoll.
Lesen und Schreiben von UNIX-Pipes.
Die akzeptierte Syntax ist:
Rohr:[ ]
Anzahl ist die Nummer, die dem Dateideskriptor der Pipe entspricht (zB 0 für stdin, 1
für stdout, 2 für stderr). Wenn Anzahl nicht angegeben ist, standardmäßig die stdout-Datei
descriptor wird zum Schreiben verwendet, stdin zum Lesen.
Zum Beispiel um aus stdin zu lesen mit ffmpeg:
Katzentest.wav | ffmpeg -i Rohr: 0
# ...das ist dasselbe wie...
Katzentest.wav | ffmpeg -i-Rohr:
Zum Schreiben auf Standard mit ffmpeg:
ffmpeg -i test.wav -f avi pipe:1 | Katze > test.avi
# ...das ist dasselbe wie...
ffmpeg -i test.wav -f avi-Pipe: | Katze > test.avi
Dieses Protokoll akzeptiert die folgenden Optionen:
Block Größe
Legen Sie die maximale Blockgröße für die E/A-Operation in Byte fest. Der Standardwert ist "INT_MAX", was
führt dazu, dass die angeforderte Blockgröße nicht begrenzt wird. Setzen Sie diesen Wert angemessen niedrig
Verbessert die Reaktionszeit von Benutzerbeendigungsanfragen, was wertvoll ist, wenn Daten
die Übertragung ist langsam.
Beachten Sie, dass einige Formate (normalerweise MOV) erfordern, dass das Ausgabeprotokoll durchsucht werden kann
sie werden mit dem Pipe-Ausgabeprotokoll fehlschlagen.
rtmp
Echtzeit-Messaging-Protokoll.
Das Real-Time Messaging Protocol (RTMP) wird zum Streamen von Multimedia-Inhalten über ein
TCP/IP-Netzwerk.
Die erforderliche Syntax lautet:
rtmp://[ : @] [: ][/ ][/ ][/ ]
Die akzeptierten Parameter sind:
Benutzername
Ein optionaler Benutzername (meist zum Veröffentlichen).
Passwort
Ein optionales Passwort (meist für die Veröffentlichung).
Server
Die Adresse des RTMP-Servers.
port
Die Nummer des zu verwendenden TCP-Ports (standardmäßig ist 1935).
App Es ist der Name der Anwendung, auf die zugegriffen werden soll. Es entspricht normalerweise dem Pfad, wo
die Anwendung wird auf dem RTMP-Server installiert (zB /auf Nachfrage/, /blitzen/leben/, Etc.).
Sie können den aus dem URI geparsten Wert auch über die Option "rtmp_app" überschreiben.
Spielpfad
Es ist der Pfad oder Name der Ressource, die mit Verweis auf die Anwendung wiedergegeben werden soll
spezifiziert in App, kann mit "mp4:" vorangestellt werden. Sie können den geparsten Wert überschreiben
die URI auch über die Option "rtmp_playpath".
hören
Als Server fungieren und auf eine eingehende Verbindung warten.
Timeout
Maximale Wartezeit auf die eingehende Verbindung. Bedeutet zuhören.
Darüber hinaus können die folgenden Parameter über Befehlszeilenoptionen (oder im Code über
"AVOptionen":
rtmp_app
Name der Anwendung, die auf dem RTMP-Server verbunden werden soll. Diese Option überschreibt den Parameter
in der URI angegeben.
rtmp_buffer
Legen Sie die Client-Pufferzeit in Millisekunden fest. Der Standardwert ist 3000.
rtmp_conn
Zusätzliche beliebige AMF-Verbindungsparameter, geparst aus einem String, zB wie "B:1
S:authMe O:1 NN:code:1.23 NS:flag:ok O:0". Jedem Wert ist ein einzelnes vorangestellt
Zeichen, das den Typ angibt, B für Boolean, N für Zahl, S für String, O für Objekt,
oder Z für null, gefolgt von einem Doppelpunkt. Für Boolesche Werte müssen die Daten entweder 0 oder 1 sein für
FALSE bzw. TRUE. Ebenso müssen die Daten für Objekte 0 oder 1 sein, um zu enden oder
beginnen jeweils ein Objekt. Datenelemente in Unterobjekten können benannt werden, indem Sie das voranstellen
Geben Sie 'N' ein und geben Sie den Namen vor dem Wert an (zB "NB:myFlag:1"). Dies
Option kann mehrmals verwendet werden, um beliebige AMF-Sequenzen zu konstruieren.
rtmp_flashver
Version des Flash-Plugins, das zum Ausführen des SWF-Players verwendet wird. Der Standardwert ist LNX 9,0,124,2.
(Bei der Veröffentlichung ist die Standardeinstellung FMLE/3.0 (kompatibel; ).)
rtmp_flush_interval
Anzahl der Pakete, die in derselben Anfrage geleert werden (nur RTMPT). Der Standardwert ist 10.
rtmp_live
Geben Sie an, dass das Medium ein Livestream ist. Kein Fortsetzen oder Suchen in Livestreams ist
möglich. Der Standardwert ist "any", was bedeutet, dass der Abonnent zuerst versucht zu spielen
der im Wiedergabepfad angegebene Livestream. Wenn kein Livestream mit diesem Namen gefunden wird,
es spielt den aufgezeichneten Stream ab. Die anderen möglichen Werte sind "live" und "recorded".
rtmp_pageurl
URL der Webseite, in die das Medium eingebettet wurde. Standardmäßig wird kein Wert gesendet.
rtmp_playpath
Stream-ID zum Abspielen oder Veröffentlichen. Diese Option überschreibt den angegebenen Parameter
in der URI.
rtmp_subscribe
Name des Livestreams, den Sie abonnieren möchten. Standardmäßig wird kein Wert gesendet. Es ist nur
wird gesendet, wenn die Option angegeben ist oder wenn rtmp_live auf live gesetzt ist.
rtmp_swfhash
SHA256-Hash der dekomprimierten SWF-Datei (32 Byte).
rtmp_swfsize
Größe der dekomprimierten SWF-Datei, erforderlich für SWFVerification.
rtmp_swfurl
URL des SWF-Players für die Medien. Standardmäßig wird kein Wert gesendet.
rtmp_swfverify
URL zur Player-SWF-Datei, Hash/Größe automatisch berechnen.
rtmp_tcurl
URL des Zielstreams. Standardmäßig ist proto://host[:port]/app.
Zum Beispiel zum Lesen mit ffplay eine Multimedia-Ressource namens "sample" aus der Anwendung
"vod" von einem RTMP-Server "myserver":
ffplay rtmp://myserver/vod/sample
So veröffentlichen Sie auf einem passwortgeschützten Server, indem Sie den Playpath- und App-Namen separat übergeben:
ffmpeg -re -i -f flv -rtmp_playpath some/long/path -rtmp_app long/app/name rtmp://username:password@myserver/
rtmpe
Verschlüsseltes Echtzeit-Messaging-Protokoll.
Das Encrypted Real-Time Messaging Protocol (RTMPE) wird für das Streaming von Multimedia verwendet
Inhalt innerhalb von standardmäßigen kryptografischen Primitiven, bestehend aus Diffie-Hellman-Schlüssel
Exchange und HMACSHA256, die ein Paar von RC4-Schlüsseln generieren.
rtmps
Real-Time Messaging Protocol über eine sichere SSL-Verbindung.
Das Real-Time Messaging Protocol (RTMPS) wird für das Streaming von Multimediainhalten verwendet
eine verschlüsselte Verbindung.
rtmpt
Durch HTTP getunneltes Echtzeit-Messaging-Protokoll.
Das über HTTP getunnelte Real-Time Messaging Protocol (RTMPT) wird für das Streaming verwendet
Multimedia-Inhalte in HTTP-Anforderungen, um Firewalls zu durchqueren.
rtmpte
Verschlüsseltes Echtzeit-Messaging-Protokoll, das über HTTP getunnelt wird.
Das verschlüsselte Echtzeit-Messaging-Protokoll, das über HTTP (RTMPTE) getunnelt wird, wird verwendet für
Streaming von Multimediainhalten innerhalb von HTTP-Anforderungen, um Firewalls zu durchqueren.
rtmpts
Durch HTTPS getunneltes Echtzeit-Messaging-Protokoll.
Für das Streaming wird das über HTTPS getunnelte Real-Time Messaging Protocol (RTMPTS) verwendet
Multimedia-Inhalte in HTTPS-Anforderungen, um Firewalls zu durchqueren.
libsmbclient
libsmbclient erlaubt es, CIFS/SMB-Netzwerkressourcen zu manipulieren.
Folgende Syntax ist erforderlich.
smb://[[Domäne:]Benutzer[:Passwort@]]Server[/Freigabe[/Pfad[/Datei]]]
Dieses Protokoll akzeptiert die folgenden Optionen.
Timeout
Legen Sie das Timeout in Millisekunden für Socket-I/O-Operationen fest, die von der zugrunde liegenden niedrigen Ebene verwendet werden
Betrieb. Standardmäßig ist es auf -1 gesetzt, was bedeutet, dass das Timeout nicht angegeben ist.
abschneiden
Vorhandene Dateien beim Schreiben abschneiden, wenn auf 1 gesetzt. Ein Wert von 0 verhindert das Abschneiden.
Der Standardwert ist 1.
Arbeitsgruppe
Legen Sie die Arbeitsgruppe fest, die zum Herstellen von Verbindungen verwendet wird. Standardmäßig ist keine Arbeitsgruppe angegeben.
Weitere Informationen finden Sie unter:http://www.samba.org/>.
libssh
Secure File Transfer Protocol über libssh
Lesen von oder Schreiben von Remoteressourcen mithilfe des SFTP-Protokolls.
Folgende Syntax ist erforderlich.
sftp://[Benutzer[:Passwort]@]Server[:Port]/Pfad/zu/Remote/Ressource.mpeg
Dieses Protokoll akzeptiert die folgenden Optionen.
Timeout
Legen Sie das Timeout für Socket-E/A-Operationen fest, die von der zugrunde liegenden Operation auf niedriger Ebene verwendet werden. Von
Standardmäßig ist sie auf -1 gesetzt, was bedeutet, dass die Zeitüberschreitung nicht angegeben ist.
abschneiden
Vorhandene Dateien beim Schreiben abschneiden, wenn auf 1 gesetzt. Ein Wert von 0 verhindert das Abschneiden.
Der Standardwert ist 1.
Privat Schlüssel
Geben Sie den Pfad der Datei an, die den privaten Schlüssel enthält, der während der Autorisierung verwendet werden soll. Von
default libssh sucht nach Schlüsseln im ~ / .ssh / Verzeichnis.
Beispiel: Spielen Sie eine Datei ab, die auf einem Remote-Server gespeichert ist.
ffplay sftp://Benutzer:password@server_address:22/home/user/resource.mpeg
librtmp rtmp, rtmpe, RTMPS, rtmpt, rtmpte
Real-Time Messaging Protocol und seine Varianten, die von librtmp unterstützt werden.
Erfordert das Vorhandensein der librtmp-Header und der Bibliothek während der Konfiguration. Du musst
Konfigurieren Sie den Build explizit mit "--enable-librtmp". Wenn aktiviert, ersetzt dies die
natives RTMP-Protokoll.
Dieses Protokoll bietet die meisten Clientfunktionen und einige Serverfunktionen, die zur Unterstützung erforderlich sind
RTMP, RTMP getunnelt in HTTP (RTMPT), verschlüsseltes RTMP (RTMPE), RTMP über SSL/TLS (RTMPS) und
getunnelte Varianten dieser verschlüsselten Typen (RTMPTE, RTMPTS).
Die erforderliche Syntax lautet:
:// [: ][/ ][/ ]
woher rtmp_proto ist einer der Strings "rtmp", "rtmpt", "rtmpe", "rtmps", "rtmpte",
"rtmpts" entsprechend jeder RTMP-Variante und Server, port , App und Spielpfad haben die
gleiche Bedeutung wie für das native RTMP-Protokoll angegeben. Optionen enthält eine Liste von Raum-
getrennte Optionen des Formulars Haupt=Welle.
Weitere Informationen finden Sie auf der Handbuchseite von librtmp (man 3 librtmp).
Um beispielsweise eine Datei in Echtzeit an einen RTMP-Server zu streamen, verwenden Sie ffmpeg:
ffmpeg -re -i myfile -f flv rtmp://myserver/live/mystream
Um denselben Stream mit . abzuspielen ffplay:
ffplay "rtmp://myserver/live/mystream live=1"
rtp
Echtzeit-Transportprotokoll.
Die erforderliche Syntax für eine RTP-URL lautet: rtp://hostname[:port ][?zu erhalten=Welle...]
port gibt den zu verwendenden RTP-Port an.
Die folgenden URL-Optionen werden unterstützt:
ttl=n
Stellen Sie den TTL-Wert (Time-To-Live) ein (nur für Multicast).
rtcport=n
Stellen Sie den Remote-RTCP-Port auf n.
localrtport=n
Stellen Sie den lokalen RTP-Port auf n.
localrtcport=n'
Setzen Sie den lokalen RTCP-Port auf n.
pkt_size=n
Setze die maximale Paketgröße (in Bytes) auf n.
verbinden=0|1
Führen Sie ein "connect()" auf dem UDP-Socket aus (wenn auf 1 gesetzt oder nicht (wenn auf 0 gesetzt).
Quellen=ip[,ip]
Listen Sie die zulässigen Quell-IP-Adressen auf.
block=ip[,ip]
Listet unzulässige (blockierte) Quell-IP-Adressen auf.
write_to_source=0|1
Senden Sie Pakete an die Quelladresse des zuletzt empfangenen Pakets (wenn auf 1 gesetzt) oder an a
Standard-Remote-Adresse (wenn auf 0 gesetzt).
localport=n
Stellen Sie den lokalen RTP-Port auf n.
Dies ist eine veraltete Option. Stattdessen, localrtport sollte benutzt werden.
Wichtige Hinweise:
1. Wenn rtcport nicht gesetzt ist, wird der RTCP-Port auf den RTP-Port-Wert plus 1 gesetzt.
2. Wenn localrtport (der lokale RTP-Port) ist nicht eingestellt, es wird kein verfügbarer Port verwendet für
die lokalen RTP- und RTCP-Ports.
3. Wenn localrtcport (der lokale RTCP-Port) nicht eingestellt ist, wird er auf den lokalen RTP-Port eingestellt
Wert plus 1.
rTSP
Echtzeit-Streaming-Protokoll.
RTSP ist technisch gesehen kein Protokollhandler im libavformat, sondern ein Demuxer und Muxer. Die
Demuxer unterstützt sowohl normales RTSP (mit Datentransfer über RTP; dies wird von z
Apple und Microsoft) und Real-RTSP (mit Datentransfer über RDT).
Der Muxer kann verwendet werden, um einen Stream mit RTSP ANNOUNCE an einen Server zu senden, der ihn unterstützt
(derzeit Darwin Streaming Server und Mischa Spiegelmocks
<https://github.com/revmischa/rtsp-server>).
Die erforderliche Syntax für eine RTSP-URL lautet:
rtsp:// [: ]/
Optionen können auf dem . eingestellt werden ffmpeg/ffplay Befehlszeile oder im Code über "AVOption"s oder in
"avformat_open_input".
Die folgenden Optionen werden unterstützt.
initial_pause
Starten Sie die Wiedergabe des Streams nicht sofort, wenn der Wert auf 1 gesetzt ist. Der Standardwert ist 0.
rtsp_transport
Legen Sie RTSP-Transportprotokolle fest.
Es akzeptiert die folgenden Werte:
UDP Verwenden Sie UDP als unteres Transportprotokoll.
TCP Verwenden Sie TCP (Interleaving innerhalb des RTSP-Kontrollkanals) als unteren Transport
Protokoll.
udp_multicast
Verwenden Sie UDP-Multicast als unteres Transportprotokoll.
http
Verwenden Sie HTTP-Tunneling als niedrigeres Transportprotokoll, das für die Weitergabe nützlich ist
Stellvertreter.
Es können mehrere niedrigere Transportprotokolle angegeben werden, in diesem Fall werden sie eines versucht
(wenn die Einrichtung von einem fehlschlägt, wird das nächste versucht). Für den Muxer nur die
TCP und UDP Optionen werden unterstützt.
rtsp_flags
Setzen Sie RTSP-Flags.
Folgende Werte werden akzeptiert:
filter_src
Akzeptieren Sie Pakete nur von ausgehandelter Peer-Adresse und Port.
hören
Als Server fungieren und auf eine eingehende Verbindung warten.
bevorzugt_tcp
Versuchen Sie zuerst TCP für den RTP-Transport, wenn TCP als RTSP-RTP-Transport verfügbar ist.
Standardwert ist keine.
allow_media_types
Legen Sie Medientypen fest, die vom Server akzeptiert werden sollen.
Folgende Flags werden akzeptiert:
Video
Audio-
die Datenerfassung
Standardmäßig werden alle Medientypen akzeptiert.
min_port
Legen Sie den minimalen lokalen UDP-Port fest. Der Standardwert ist 5000.
max_port
Legen Sie den maximalen lokalen UDP-Port fest. Der Standardwert ist 65000.
Timeout
Legen Sie das maximale Timeout (in Sekunden) fest, um auf eingehende Verbindungen zu warten.
Ein Wert von -1 bedeutet unendlich (Standard). Diese Option impliziert die rtsp_flags einstellen
hören.
reorder_queue_size
Legen Sie die Anzahl der zu puffernden Pakete fest, um neu geordnete Pakete zu verarbeiten.
Zeitüberschreitung
Legen Sie das Socket-TCP-E/A-Timeout in Mikrosekunden fest.
User-Agent
Überschreiben Sie den User-Agent-Header. Wenn nicht angegeben, wird standardmäßig das libavformat verwendet
Identifier-String.
Beim Empfangen von Daten über UDP versucht der Demuxer, empfangene Pakete neu zu ordnen (da sie
kann nicht in der richtigen Reihenfolge ankommen oder Pakete können vollständig verloren gehen). Dies kann durch die Einstellung deaktiviert werden
die maximale Demuxing-Verzögerung auf Null (über das "max_delay"-Feld von AVFormatContext).
Beim Ansehen von Real-RTSP-Streams mit mehreren Bitraten mit ffplay, können die anzuzeigenden Streams sein
ausgewählt mit "-vst" n und "-ast" n für Video bzw. Audio und zuschaltbar
die Fliege durch Drücken von "v" und "a".
Beispiele
Die folgenden Beispiele verwenden alle die ffplay und ffmpeg Werkzeuge.
· Sehen Sie sich einen Stream über UDP an, mit einer maximalen Neuordnungsverzögerung von 0.5 Sekunden:
ffplay -max_delay 500000 -rtsp_transport udp rtsp://server/video.mp4
· Sehen Sie sich einen über HTTP getunnelten Stream an:
ffplay -rtsp_transport http rtsp://server/video.mp4
· Senden Sie einen Stream in Echtzeit an einen RTSP-Server, damit andere ihn sehen können:
ffmpeg -re -i -f rtsp -muxdelay 0.1 rtsp://server/live.sdp
· Empfangen Sie einen Stream in Echtzeit:
ffmpeg -rtsp_flags hören -i rtsp://ownaddress/live.sdp
Saft
Sitzungsankündigungsprotokoll (RFC 2974). Dies ist technisch gesehen kein Protokollhandler in
libavformat, es ist ein Muxer und Demuxer. Es wird zur Signalisierung von RTP-Streams verwendet, von
die SDP für die Streams regelmäßig auf einem separaten Port ankündigen.
Frau
Die Syntax für eine dem Muxer übergebene SAP-URL lautet:
Saft:// [: ][? ]
Die RTP-Pakete werden gesendet an Reiseziel am Hafen port , oder zu Port 5004, wenn kein Port vorhanden ist
spezifiziert. Optionen ist eine durch "&" getrennte Liste. Die folgenden Optionen werden unterstützt:
ankündigen_addr=Adresse
Geben Sie die Ziel-IP-Adresse an, an die die Ankündigungen gesendet werden sollen. Wenn es weggelassen wird, wird das
Ankündigungen werden an die häufig verwendete SAP-Ankündigungs-Multicast-Adresse gesendet
224.2.127.254 (sap.mcast.net) oder ff0e::2:7ffe wenn Reiseziel ist eine IPv6-Adresse.
ankündigen_port=port
Geben Sie den Port an, über den die Ankündigungen gesendet werden sollen, standardmäßig 9875, wenn nicht angegeben.
ttl=ttl
Geben Sie den Time-to-Live-Wert für die Ansagen und RTP-Pakete an, der Standardwert ist 255.
gleicher_port=0 | 1
Wenn auf 1 gesetzt, senden Sie alle RTP-Streams auf demselben Portpaar. Wenn null (Standardeinstellung), all
Streams werden an eindeutigen Ports gesendet, wobei jeder Stream an einem Port 2 Nummern höher als der
früher. VLC/Live555 erfordert, dass dies auf 1 gesetzt wird, um den Stream empfangen zu können.
Der RTP-Stack im libavformat zum Empfangen erfordert, dass alle Streams auf eindeutigem gesendet werden
Häfen
Es folgen Beispielbefehlszeilen.
So senden Sie einen Stream im lokalen Subnetz zum Ansehen in VLC:
ffmpeg -re -i -f sap sap://224.0.0.255?same_port=1
Ebenso zum Anschauen in ffplay:
ffmpeg -re -i -f sap sap://224.0.0.255
Und zum Zuschauen ffplay, über IPv6:
ffmpeg -re -i -f sap sap://[ff0e::1:2:3:4]
Demuxer
Die Syntax für eine dem Demuxer übergebene SAP-URL lautet:
Saft://[ ][: ]
Adresse ist die Multicast-Adresse, auf der Ansagen abgehört werden sollen, wenn sie weggelassen wird, ist dies der Standard
224.2.127.254 (sap.mcast.net) wird verwendet. port ist der Port, der abgehört wird, 9875, wenn
weggelassen.
Der Demuxer lauscht auf Durchsagen auf der angegebenen Adresse und dem Port. Einmal
Ansage empfangen wird, versucht es, diesen bestimmten Stream zu empfangen.
Es folgen Beispielbefehlszeilen.
So geben Sie den ersten an der normalen SAP-Multicast-Adresse angesagten Stream wieder:
ffplay sap://
So geben Sie den ersten Stream wieder, der auf einer der standardmäßigen IPv6-SAP-Multicast-Adressen angesagt wird:
ffplay sap://[ff0e::2:7ffe]
sctp
Stream Control-Übertragungsprotokoll.
Die akzeptierte URL-Syntax ist:
sctp:// : [? ]
Das Protokoll akzeptiert die folgenden Optionen:
hören
Wenn auf einen Wert gesetzt, warten Sie auf eine eingehende Verbindung. Ausgehende Verbindung erfolgt durch
default.
max_streams
Legen Sie die maximale Anzahl von Streams fest. Standardmäßig ist kein Limit festgelegt.
srtp
Sicheres Echtzeit-Transportprotokoll.
Die akzeptierten Optionen sind:
srtp_in_suite
srtp_out_suite
Wählen Sie die Encoding-Suiten für die Eingabe und Ausgabe aus.
Unterstützte Werte:
AES_CM_128_HMAC_SHA1_80
SRTP_AES128_CM_HMAC_SHA1_80
AES_CM_128_HMAC_SHA1_32
SRTP_AES128_CM_HMAC_SHA1_32
srtp_in_params
srtp_out_params
Legen Sie Eingabe- und Ausgabecodierungsparameter fest, die durch ein base64-codiertes . ausgedrückt werden
Darstellung eines binären Blocks. Die ersten 16 Byte dieses Binärblocks werden als
Masterschlüssel, die folgenden 14 Byte werden als Master Salt verwendet.
Unterdatei
Extrahieren Sie virtuell ein Segment einer Datei oder eines anderen Streams. Der zugrunde liegende Stream muss
suchbar.
Akzeptierte Optionen:
Anfang
Start-Offset des extrahierten Segments in Byte.
Ende Endoffset des extrahierten Segments in Byte.
Beispiele:
Extrahieren Sie ein Kapitel aus einer DVD-VOB-Datei (extern bezogener Start- und Endsektor und
multipliziert mit 2048):
Unterdatei,,start,153391104,end,268142592,,:/media/dvd/VIDEO_TS/VTS_08_1.VOB
Spielen Sie eine AVI-Datei direkt aus einem TAR-Archiv ab:
Unterdatei,,start,183241728,end,366490624,,:archive.tar
TCP
Übertragungskontrollprotokoll.
Die erforderliche Syntax für eine TCP-URL lautet:
tcp:// : [? ]
Optionen enthält eine Liste von &-getrennten Optionen des Formulars Haupt=Welle.
Die Liste der unterstützten Optionen folgt.
zuhören=1 | 0
Hören Sie auf eine eingehende Verbindung. Der Standardwert ist 0.
Auszeit=Mikrosekunden
Legen Sie die Zeitüberschreitung für den Erhöhungsfehler fest, ausgedrückt in Mikrosekunden.
Diese Option ist nur im Lesemodus relevant: wenn länger als diese Zeit keine Daten eingetroffen sind
Intervall, Fehler erhöhen.
listen_timeout=Millisekunden
Legen Sie die Zeitüberschreitung für das Abhören fest, ausgedrückt in Millisekunden.
Das folgende Beispiel zeigt, wie Sie eine hörende TCP-Verbindung mit einrichten ffmpeg, Das ist
dann aufgerufen mit ffplay:
ffmpeg -i -F tcp:// : ?hören
ffplay tcp:// :
tls
Transport Layer Security (TLS) / Secure Sockets Layer (SSL)
Die erforderliche Syntax für eine TLS/SSL-URL lautet:
tls:// : [? ]
Die folgenden Parameter können über Befehlszeilenoptionen (oder im Code über "AVOption"s) eingestellt werden:
ca_Datei, cafile=Dateinamen
Eine Datei, die Stammzertifikate der Zertifizierungsstelle (CA) enthält, die als vertrauenswürdig behandelt werden sollen. Wenn
die verknüpfte TLS-Bibliothek enthält eine Standardeinstellung, für die möglicherweise keine Angabe erforderlich ist
Überprüfung funktioniert, aber nicht alle Bibliotheken und Setups verfügen über integrierte Standardeinstellungen
Datei muss im OpenSSL PEM-Format vorliegen.
tls_verify=1 | 0
Wenn diese Option aktiviert ist, versuchen Sie, den Peer zu überprüfen, mit dem wir kommunizieren. Beachten Sie, wenn Sie . verwenden
OpenSSL, dies stellt derzeit nur sicher, dass das Peer-Zertifikat von einem der
die Root-Zertifikate in der CA-Datenbank, aber es bestätigt nicht, dass die
Das Zertifikat stimmt tatsächlich mit dem Hostnamen überein, zu dem wir eine Verbindung herstellen möchten. (Mit GnuTLS,
der Hostname wird ebenfalls validiert.)
Dies ist standardmäßig deaktiviert, da eine CA-Datenbank von der
Anrufer in vielen Fällen.
Zertifikatsdatei, zertifikat=Dateinamen
Eine Datei, die ein Zertifikat enthält, das im Handshake mit dem Peer verwendet werden soll. (Wann
Betrieb als Server, im Listen-Modus wird dies häufiger vom Peer benötigt, während
Nur Client-Zertifikate sind in bestimmten Konfigurationen vorgeschrieben.)
Schlüsseldatei, Schlüssel =Dateinamen
Eine Datei, die den privaten Schlüssel für das Zertifikat enthält.
zuhören=1 | 0
Wenn aktiviert, lauschen Sie auf Verbindungen auf dem bereitgestellten Port und übernehmen Sie die Serverrolle in
der Handshake anstelle der Client-Rolle.
Beispielbefehlszeilen:
Um einen TLS/SSL-Server zu erstellen, der einen Eingabestream bereitstellt.
ffmpeg -i -F tls:// : ?hören&cert= &taste=
So geben Sie einen Stream vom TLS/SSL-Server mit . wieder ffplay:
ffplay tls:// :
UDP
Benutzer-Datagramm-Protokoll.
Die erforderliche Syntax für eine UDP-URL lautet:
udp:// : [? ]
Optionen enthält eine Liste von &-getrennten Optionen des Formulars Haupt=Welle.
Falls Threading auf dem System aktiviert ist, wird ein Ringpuffer verwendet, um die
eingehende Daten, wodurch Datenverluste aufgrund von UDP-Socket-Pufferüberläufen reduziert werden können.
Die fifo_size und overrun_nonfatal Optionen beziehen sich auf diesen Puffer.
Die Liste der unterstützten Optionen folgt.
Puffergröße=Größe
Legen Sie die maximale UDP-Socket-Puffergröße in Byte fest. Dies wird verwendet, um entweder die
Empfangs- oder Sendepuffergröße, je nachdem, wofür der Socket verwendet wird. Standard ist
64KB. Siehe auch fifo_size.
localport=port
Überschreiben Sie den lokalen UDP-Port für die Bindung.
localadr=Adr
Wählen Sie die lokale IP-Adresse aus. Dies ist zB beim Senden von Multicast nützlich und der Host hat
mehrere Schnittstellen, bei denen der Benutzer auswählen kann, über welche Schnittstelle er gesendet werden soll
Angabe der IP-Adresse dieser Schnittstelle.
pkt_size=Größe
Legen Sie die Größe von UDP-Paketen in Byte fest.
wiederverwenden=1 | 0
Erlauben oder verbieten Sie explizit die Wiederverwendung von UDP-Sockets.
ttl=ttl
Stellen Sie den Time-to-Live-Wert ein (nur für Multicast).
verbinden=1 | 0
Initialisieren Sie den UDP-Socket mit "connect()". In diesem Fall ist die Zieladresse
kann später nicht mehr mit ff_udp_set_remote_url geändert werden. Wenn die Zieladresse nicht ist
zu Beginn bekannt, kann diese Option auch in ff_udp_set_remote_url angegeben werden. Dies
ermöglicht das Herausfinden der Quelladresse für die Pakete mit getsockname und macht
schreibt Rückgabe mit AVERROR(ECONNREFUSED), wenn "Ziel nicht erreichbar" empfangen wird.
Beim Empfangen hat dies den Vorteil, dass nur Pakete von den angegebenen empfangen werden
Peer-Adresse/Port.
Quellen=Adresse[,Adresse]
Nur Pakete empfangen, die an die Multicast-Gruppe von einer der angegebenen Absender-IP gesendet werden
Adressen.
block=Adresse[,Adresse]
Ignorieren Sie Pakete, die von den angegebenen Absender-IP-Adressen an die Multicast-Gruppe gesendet werden.
fifo_size=Bereiche
Legen Sie die Größe des UDP-Empfangskreispuffers fest, ausgedrückt als Anzahl von Paketen mit Größe
von 188 Byte. Wenn nicht angegeben, wird standardmäßig 7*4096 verwendet.
overrun_nonfatal=1 | 0
Überlebe bei UDP-Empfangsringpufferüberlauf. Der Standardwert ist 0.
Auszeit=Mikrosekunden
Legen Sie die Zeitüberschreitung für den Erhöhungsfehler fest, ausgedrückt in Mikrosekunden.
Diese Option ist nur im Lesemodus relevant: wenn länger als diese Zeit keine Daten eingetroffen sind
Intervall, Fehler erhöhen.
Sendung=1 | 0
Erlauben oder verbieten Sie explizit UDP-Broadcasting.
Beachten Sie, dass die Übertragung in Netzwerken mit einem Broadcast-Sturm möglicherweise nicht richtig funktioniert
Schutz.
Beispiele
· Verwenden ffmpeg So streamen Sie über UDP zu einem Remote-Endpunkt:
ffmpeg -i -F udp:// :
· Verwenden ffmpeg um im MPEGts-Format über UDP mit 188 großen UDP-Paketen zu streamen, mit a
großer Eingabepuffer:
ffmpeg -i -f mpegts udp:// : ?pkt_size=188&buffer_size=65535
· Verwenden ffmpeg um über UDP von einem Remote-Endpunkt zu empfangen:
ffmpeg -i udp://[ ]: ...
Unix
Lokaler Unix-Socket
Die erforderliche Syntax für eine Unix-Socket-URL lautet:
unix://
Die folgenden Parameter können über Befehlszeilenoptionen (oder im Code über "AVOption"s) eingestellt werden:
Timeout
Zeitüberschreitung in ms.
hören
Erstellen Sie den Unix-Socket im Listening-Modus.
DEVICE OPTIONAL
Die Bibliothek libavdevice bietet dieselbe Schnittstelle wie libavformat. Nämlich eine Eingabe
Gerät wird wie ein Demuxer und ein Ausgabegerät wie ein Muxer betrachtet, und die Schnittstelle
und generische Geräteoptionen sind die gleichen, die von libavformat bereitgestellt werden (siehe die ffmpeg-Formate
Handbuch).
Darüber hinaus kann jedes Eingabe- oder Ausgabegerät sogenannte private Optionen unterstützen, die
spezifisch für diese Komponente.
Optionen können eingestellt werden durch Angabe von -zu erhalten Wert in den FFmpeg-Tools oder durch Einstellen der
Wert explizit in den Geräteoptionen "AVFormatContext" oder über die libavutil/opt.h API
für den programmatischen Einsatz.
SPEISUNG GERÄTE
Eingabegeräte sind konfigurierte Elemente in FFmpeg, die den Zugriff auf die ankommenden Daten ermöglichen
von einem an Ihr System angeschlossenen Multimediagerät.
Wenn Sie Ihren FFmpeg-Build konfigurieren, werden alle unterstützten Eingabegeräte aktiviert durch
Ursprünglich. Sie können alle verfügbaren mit der Konfigurationsoption "--list-indevs" auflisten.
Sie können alle Eingabegeräte mit der Konfigurationsoption "--disable-indevs" deaktivieren und
Aktivieren Sie selektiv ein Eingabegerät mit der Option "--enable-indev=INDEV", oder du kannst
deaktivieren Sie ein bestimmtes Eingabegerät mit der Option "--disable-indev=INDEV".
Die Option "-devices" des ff*-Tools zeigt die Liste der unterstützten Eingabegeräte an.
Es folgt eine Beschreibung der derzeit verfügbaren Eingabegeräte.
auch
ALSA-Eingabegerät (Advanced Linux Sound Architecture).
Um dieses Eingabegerät während der Konfiguration zu aktivieren, muss libasound auf Ihrem
System funktionieren.
Dieses Gerät ermöglicht die Aufnahme von einem ALSA-Gerät. Der Name des aufzunehmenden Geräts muss
eine ALSA-Kartenkennung sein.
Ein ALSA-Bezeichner hat die Syntax:
wie: [, [, ]]
wo die DEV und UNTERDEV Komponenten sind optional.
Die drei Argumente (in der Reihenfolge: CARD,DEV,UNTERDEV) Kartennummer oder Kennung angeben, Gerät
Nummer und Untergerätenummer (-1 bedeutet beliebig).
Um die Liste der Karten anzuzeigen, die derzeit von Ihrem System erkannt werden, überprüfen Sie die Dateien
/ proc / asound / Karten und /proc/asound/devices.
Zum Beispiel zum Aufnehmen mit ffmpeg von einem ALSA-Gerät mit der Karten-ID 0 können Sie die
Befehl:
ffmpeg -f alsa -i hw:0 alsaout.wav
Weitere Informationen finden Sie unter:http://www.alsa-project.org/alsa-doc/alsa-lib/pcm.html>
Optionen
Beispielrate
Stellen Sie die Abtastrate in Hz ein. Der Standardwert ist 48000.
Kanäle
Stellen Sie die Anzahl der Kanäle ein. Standard ist 2.
grundierung
AVFoundation-Eingabegerät.
AVFoundation ist das derzeit von Apple empfohlene Framework für Streamgrabbing unter OSX >=
10.7 sowie auf iOS. Das ältere QTKit-Framework wurde seit OSX als veraltet markiert
Version 10.7.
Der Eingabedateiname muss in der folgenden Syntax angegeben werden:
-i "[[VIDEO]:[AUDIO]]"
Der erste Eintrag wählt den Videoeingang aus, während der letztere den Audioeingang auswählt. Die
stream muss durch den Gerätenamen oder den Geräteindex angegeben werden, wie vom Gerät angezeigt
aufführen. Alternativ kann das Video- und/oder Audio-Eingabegerät per Index über die ausgewählt werden
B<-video_device_index E INDEXE >
und / oder
B<-audio_device_index E INDEXE >
, überschreibt jeden Gerätenamen oder Index, der im Eingabedateinamen angegeben ist.
Alle verfügbaren Geräte können mit aufgezählt werden -list_devices was immer dies auch sein sollte., alle Geräte auflisten
Namen und entsprechende Indizes.
Es gibt zwei Aliasse für Gerätenamen:
"Default"
Wählen Sie das AVFoundation-Standardgerät des entsprechenden Typs aus.
„Keine“
Nehmen Sie nicht den entsprechenden Medientyp auf. Dies entspricht der Angabe eines leeren
Gerätename oder Index.
Optionen
AVFoundation unterstützt die folgenden Optionen:
-list_devices
Wenn auf true gesetzt, wird eine Liste aller verfügbaren Eingabegeräte mit allen Geräten angezeigt
Namen und Indizes.
-video_device_index
Geben Sie das Videogerät durch seinen Index an. Überschreibt alles, was im Eingabedateinamen angegeben ist.
-audio_device_index
Geben Sie das Audiogerät durch seinen Index an. Überschreibt alles, was im Eingabedateinamen angegeben ist.
-pixel_format
Fordern Sie das Videogerät auf, ein bestimmtes Pixelformat zu verwenden. Wenn das angegebene Format . ist
nicht unterstützt, eine Liste der verfügbaren Formate wird angezeigt und das erste in dieser Liste ist
stattdessen verwendet. Verfügbare Pixelformate sind: "monob, rgb555be, rgb555le, rgb565be,
rgb565le, rgb24, bgr24, 0rgb, bgr0, 0bgr, rgb0,
bgr48be, uyvy422, yuva444p, yuva444p16le, yuv444p, yuv422p16, yuv422p10, yuv444p10,
yuv420p, nv12, yuyv422, grau"
-Framerate
Stellen Sie die Aufnahme-Bildrate ein. Standard ist "ntsc", entsprechend einer Bildrate von
"30000/1001".
-Video Größe
Stellen Sie die Videobildgröße ein.
-capture_cursor
Erfassen Sie den Mauszeiger. Standard ist 0.
-capture_mouse_clicks
Erfassen Sie die Mausklicks auf dem Bildschirm. Standard ist 0.
Beispiele
· Drucken Sie die Liste der von AVFoundation unterstützten Geräte aus und beenden Sie:
$ ffmpeg -f avfoundation -list_devices true -i ""
· Nehmen Sie Video von Videogerät 0 und Audio von Audiogerät 0 in out.avi auf:
$ ffmpeg -f avfoundation -i "0:0" out.avi
· Nehmen Sie Video von Videogerät 2 und Audio von Audiogerät 1 in out.avi auf:
$ ffmpeg -f avfoundation -video_device_index 2 -i ":1" out.avi
· Nehmen Sie Videos vom Standard-Videogerät des Systems im Pixelformat bgr0 auf und do
kein Audio in out.avi aufnehmen:
$ ffmpeg -f avfoundation -pixel_format bgr0 -i "default:none" out.avi
bktr
BSD-Videoeingabegerät.
Optionen
Framerate
Stellen Sie die Bildrate ein.
Video Größe
Stellen Sie die Videobildgröße ein. Standard ist "vga".
Standard
Verfügbare Werte sind:
Kumpel
ntsc
trocken
Paln
Palme
ntscj
Decklink
Das Decklink-Eingabegerät bietet Aufnahmefunktionen für Blackmagic DeckLink-Geräte.
Um dieses Eingabegerät zu aktivieren, benötigen Sie das Blackmagic DeckLink SDK und Sie müssen
mit den entsprechenden "--extra-cflags" und "--extra-ldflags" konfigurieren. Unter Windows können Sie
müssen die IDL-Dateien durchlaufen frei.
DeckLink ist bei den unterstützten Formaten sehr wählerisch. Pixelformat ist uyvy422 oder v210,
Bildrate und Videogröße müssen für Ihr Gerät mit ermittelt werden -list_formats 1. Audio
Die Abtastrate beträgt immer 48 kHz und die Anzahl der Kanäle kann 2, 8 oder 16 betragen.
Optionen
list_devices
Wenn auf was immer dies auch sein sollte., eine Geräteliste drucken und beenden. Standardmäßig auf falsch.
Listenformate
Wenn auf was immer dies auch sein sollte., eine Liste der unterstützten Formate drucken und beenden. Standardmäßig auf falsch.
bm_v210
Wenn auf 1, Video wird in 10 Bit v210 statt in uyvy422 aufgenommen. Nicht alle Blackmagic
Geräte unterstützen diese Option.
Beispiele
· Eingabegeräte auflisten:
ffmpeg -f decklink -list_devices 1 -i Dummy
· Liste unterstützter Formate:
ffmpeg -f decklink -list_formats 1 -i 'Intensity Pro'
· Videoclip mit 1080i50 aufnehmen (Format 11):
ffmpeg -f decklink -i 'Intensity Pro@11' -acodec copy -vcodec copy output.avi
· Videoclip mit 1080i50 10 Bit aufnehmen:
ffmpeg -bm_v210 1 -f decklink -i 'UltraStudio Mini Recorder@11' -acodec copy -vcodec copy output.avi
dzeigen
Windows DirectShow-Eingabegerät.
DirectShow-Unterstützung ist aktiviert, wenn FFmpeg mit dem mingw-w64-Projekt erstellt wird. Zur Zeit
nur Audio- und Videogeräte werden unterstützt.
Mehrere Geräte können als separate Eingänge geöffnet werden, sie können aber auch auf demselben geöffnet werden
Eingabe, die die Synchronität zwischen ihnen verbessern sollte.
Der Eingabename sollte folgendes Format haben:
= [: = ]
woher TYP Kann beides sein Audio- or Video und NAME/FUNKTION ist der Name des Geräts oder eine Alternative
Name ..
Optionen
Wenn keine Optionen angegeben sind, werden die Standardeinstellungen des Geräts verwendet. Wenn das Gerät dies nicht tut
die angeforderten Optionen unterstützen, wird das Öffnen fehlschlagen.
Video Größe
Legen Sie die Videogröße im aufgenommenen Video fest.
Framerate
Stellen Sie die Bildrate im aufgenommenen Video ein.
Beispielrate
Stellen Sie die Abtastrate (in Hz) des aufgenommenen Audios ein.
Beispielgröße
Legen Sie die Sample-Größe (in Bit) des aufgenommenen Audios fest.
Kanäle
Legen Sie die Anzahl der Kanäle im aufgenommenen Audio fest.
list_devices
Wenn auf was immer dies auch sein sollte., eine Geräteliste drucken und beenden.
Listenoptionen
Wenn auf was immer dies auch sein sollte., eine Liste der Optionen des ausgewählten Geräts drucken und beenden.
video_gerätenummer
Legen Sie die Videogerätenummer für Geräte mit demselben Namen fest (beginnt bei 0, Standardwert 0).
audio_geräte_nummer
Legen Sie die Audiogerätenummer für Geräte mit demselben Namen fest (beginnt bei 0, Standardwert 0).
Pixelformat
Wählen Sie das von DirectShow zu verwendende Pixelformat aus. Dies kann nur eingestellt werden, wenn das Video
Codec ist nicht gesetzt oder auf rawvideo gesetzt.
audio_buffer_size
Legen Sie die Puffergröße des Audiogeräts in Millisekunden fest (was sich direkt auf die Latenz auswirken kann,
je nach Gerät). Standardmäßig wird die Standardpuffergröße des Audiogeräts verwendet
(typischerweise ein Vielfaches von 500 ms). Eine zu niedrige Einstellung dieses Wertes kann sich verschlechtern
Leistung. Siehe auch
<http://msdn.microsoft.com/en-us/library/windows/desktop/dd377582(v=vs.85).aspx>
video_pin_name
Wählen Sie den Videoaufnahme-Pin aus, um ihn nach Namen oder alternativen Namen zu verwenden.
audio_pin_name
Wählen Sie den Audioaufnahme-Pin aus, um ihn nach Namen oder alternativen Namen zu verwenden.
crossbar_video_input_pin_number
Wählen Sie die Pinnummer des Videoeingangs für das Crossbar-Gerät. Dies wird an die Querlatte weitergeleitet
Ausgangspin des Videodecoders des Geräts. Beachten Sie, dass die Änderung dieses Werts Auswirkungen auf die Zukunft haben kann
Aufrufe (setzt einen neuen Standardwert) bis zum Neustart des Systems.
crossbar_audio_input_pin_number
Wählen Sie die Pinnummer des Audioeingangs für das Crossbar-Gerät aus. Dies wird an die Querlatte weitergeleitet
Audio-Decoder-Ausgangspin des Geräts. Beachten Sie, dass die Änderung dieses Werts Auswirkungen auf die Zukunft haben kann
Aufrufe (setzt einen neuen Standardwert) bis zum Neustart des Systems.
show_video_device_dialog
Wenn auf was immer dies auch sein sollte., bevor die Erfassung beginnt, wird dem Endbenutzer ein Anzeigedialogfeld angezeigt.
Sie können die Videofiltereigenschaften und -konfigurationen manuell ändern. Notiz
dass bei Crossbar-Geräten manchmal die Werte in diesem Dialogfeld angepasst werden müssen, um
Umschalten zwischen PAL (25 fps) und NTSC (29.97) Eingabebildraten, -größen, Interlacing,
usw. Das Ändern dieser Werte kann unterschiedliche Scanraten/Bildraten aktivieren und vermeiden
grüne Balken am unteren Rand, flackernde Scanlinien usw. Beachten Sie, dass bei einigen Geräten
Das Ändern dieser Eigenschaften kann sich auch auf zukünftige Aufrufe auswirken (setzt neue Standardeinstellungen) bis
Systemneustart erfolgt.
show_audio_device_dialog
Wenn auf was immer dies auch sein sollte., bevor die Erfassung beginnt, wird dem Endbenutzer ein Anzeigedialogfeld angezeigt.
Sie können die Audiofiltereigenschaften und -konfigurationen manuell ändern.
show_video_crossbar_connection_dialog
Wenn auf was immer dies auch sein sollte., bevor die Erfassung beginnt, wird dem Endbenutzer ein Anzeigedialogfeld angezeigt.
Dadurch können sie die Pin-Routings der Kreuzschienen manuell ändern, wenn ein Videogerät geöffnet wird.
show_audio_crossbar_connection_dialog
Wenn auf was immer dies auch sein sollte., bevor die Erfassung beginnt, wird dem Endbenutzer ein Anzeigedialogfeld angezeigt.
Dadurch können sie die Pin-Routings der Kreuzschienen manuell ändern, wenn ein Audiogerät geöffnet wird.
show_analog_tv_tuner_dialog
Wenn auf was immer dies auch sein sollte., bevor die Erfassung beginnt, wird dem Endbenutzer ein Anzeigedialogfeld angezeigt.
Damit können sie TV-Kanäle und -Frequenzen manuell ändern.
show_analog_tv_tuner_audio_dialog
Wenn auf was immer dies auch sein sollte., bevor die Erfassung beginnt, wird dem Endbenutzer ein Anzeigedialogfeld angezeigt.
ermöglicht ihnen, den TV-Ton manuell zu ändern (wie Mono vs. Stereo, Sprache A, B oder C).
audio_device_load
Laden Sie ein Audioaufnahmefiltergerät aus einer Datei, anstatt es nach Namen zu durchsuchen. Es kann
laden Sie auch zusätzliche Parameter, wenn der Filter die Serialisierung seiner
Eigenschaften zu. Um dies zu verwenden, muss eine Audio-Capture-Quelle angegeben werden, aber es kann
alles sogar gefälschte.
audio_device_save
Speichern Sie das aktuell verwendete Audio-Capture-Filtergerät und seine Parameter (wenn der Filter
unterstützt es) in eine Datei. Existiert eine Datei gleichen Namens, wird diese überschrieben.
video_device_load
Laden Sie ein Videoaufnahmefiltergerät aus einer Datei, anstatt es nach Namen zu durchsuchen. Es kann
laden Sie auch zusätzliche Parameter, wenn der Filter die Serialisierung seiner
Eigenschaften zu. Um dies zu verwenden, muss eine Videoaufnahmequelle angegeben werden, aber es kann
alles sogar gefälschte.
video_device_save
Speichern Sie das aktuell verwendete Videoaufnahmefiltergerät und seine Parameter (wenn der Filter
unterstützt es) in eine Datei. Existiert eine Datei gleichen Namens, wird diese überschrieben.
Beispiele
· Drucken Sie die Liste der von DirectShow unterstützten Geräte und beenden Sie:
$ ffmpeg -list_devices true -f dshow -i dummy
· Videogerät öffnen Kamera:
$ ffmpeg -f dshow -i video="Kamera"
· Zweites Videogerät mit Namen öffnen Kamera:
$ ffmpeg -f dshow -video_device_number 1 -i video="Kamera"
· Videogerät öffnen Kamera und Audiogerät Mikrofon:
$ ffmpeg -f dshow -i video="Kamera":audio="Mikrofon"
· Drucken Sie die Liste der unterstützten Optionen im ausgewählten Gerät und beenden Sie:
$ ffmpeg -list_options true -f dshow -i video="Kamera"
· Geben Sie Pin-Namen an, um nach Namen oder alternativen Namen zu erfassen, geben Sie alternatives Gerät an
name:
$ ffmpeg -f dshow -audio_pin_name "Audio Out" -video_pin_name 2 -i video=video="@device_pnp_\\?\pci#ven_1a0a&dev_6200&subsys_62021461&rev_01#4&e2c7dd6&0&00e1#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\{ca465100-deb0-4d59-818f-8c477184adf6}":audio="Microphone"
· Konfigurieren Sie ein Crossbar-Gerät, geben Sie Crossbar-Pins an, damit der Benutzer das Video anpassen kann
Capture-Eigenschaften beim Start:
$ ffmpeg -f dshow -show_video_device_dialog true -crossbar_video_input_pin_number 0
-crossbar_audio_input_pin_number 3 -i video="AVerMedia BDA Analog Capture":audio="AVerMedia BDA Analog Capture"
dv1394
Linux DV 1394-Eingabegerät.
Optionen
Framerate
Stellen Sie die Bildrate ein. Standard ist 25.
Standard
Verfügbare Werte sind:
Kumpel
ntsc
Der Standardwert ist "ntsc".
fbdev
Eingabegerät für Linux-Framebuffer.
Der Linux-Framebuffer ist eine von der Grafikhardware unabhängige Abstraktionsschicht zum Anzeigen von Grafiken
auf einem Computermonitor, normalerweise auf der Konsole. Der Zugriff erfolgt über ein Dateigerät
Knoten, normalerweise /dev/fb0.
Für detailliertere Informationen lesen Sie die Datei Documentation/fb/framebuffer.txt, die in . enthalten ist
den Linux-Quellbaum.
Siehe auchhttp://linux-fbdev.sourceforge.net/>, und fbset(1).
So nehmen Sie vom Framebuffer-Gerät auf /dev/fb0 mit ffmpeg:
ffmpeg -f fbdev -framerate 10 -i /dev/fb0 out.avi
Sie können ein einzelnes Screenshot-Bild mit dem Befehl erstellen:
ffmpeg -f fbdev -framerate 1 -i /dev/fb0 -frames:v 1 Screenshot.jpeg
Optionen
Framerate
Stellen Sie die Bildrate ein. Standard ist 25.
gdigrab
Win32 GDI-basiertes Bildschirmaufnahmegerät.
Mit diesem Gerät können Sie einen Bereich der Anzeige unter Windows erfassen.
Es gibt zwei Optionen für den Eingabedateinamen:
Desktop
or
Titel=
Die erste Option erfasst den gesamten Desktop oder einen festen Bereich des Desktops. Die
Die zweite Option erfasst stattdessen den Inhalt eines einzelnen Fensters, unabhängig davon
auf dem Bildschirm positionieren.
Um beispielsweise den gesamten Desktop mit zu erfassen ffmpeg:
ffmpeg -f gdigrab -framerate 6 -i desktop out.mpg
Nehmen Sie eine 640x480-Region an Position "10,20" auf:
ffmpeg -f gdigrab -framerate 6 -offset_x 10 -offset_y 20 -video_size vga -i desktop out.mpg
Holen Sie sich den Inhalt des Fensters mit dem Namen "Rechner"
ffmpeg -f gdigrab -framerate 6 -i title=Rechner out.mpg
Optionen
draw_mouse
Geben Sie an, ob der Mauszeiger gezeichnet werden soll. Verwenden Sie den Wert 0, um den Zeiger nicht zu zeichnen.
Der Standardwert ist 1.
Framerate
Stellen Sie die Aufnahme-Bildrate ein. Der Standardwert ist "ntsc", entsprechend einer Bildrate von
"30000/1001".
show_region
Zeigen Sie den erfassten Bereich auf dem Bildschirm an.
If show_region mit 1 angegeben ist, dann wird die Greifregion angezeigt auf
Bildschirm. Mit dieser Option ist es leicht zu wissen, was gegriffen wird, wenn nur eine Portion
des Bildschirms gegriffen wird.
Beachten Sie, dass show_region ist mit dem Erfassen des Inhalts eines einzelnen Fensters nicht kompatibel.
Beispielsweise:
ffmpeg -f gdigrab -show_region 1 -framerate 6 -video_size cif -offset_x 10 -offset_y 20 -i desktop out.mpg
Video Größe
Stellen Sie die Videobildgröße ein. Standardmäßig wird der Vollbildmodus aufgenommen, wenn Desktop is
ausgewählt, oder die volle Fenstergröße, wenn Titel=Fenstertitel ist ausgewählt.
offset_x
Beim Aufnehmen einer Region mit Video Größe, stellen Sie den Abstand vom linken Rand des
Bildschirm oder Desktop.
Beachten Sie, dass die Offset-Berechnung von der oberen linken Ecke des primären Monitors aus erfolgt
Fenster. Wenn Sie einen Monitor links neben Ihrem Hauptmonitor haben, können Sie
muss ein Negativ verwenden offset_x Wert, um die Region auf diesen Monitor zu verschieben.
offset_y
Beim Aufnehmen einer Region mit Video Größe, stellen Sie den Abstand von der Oberkante des
Bildschirm oder Desktop.
Beachten Sie, dass die Offset-Berechnung von der oberen linken Ecke des primären Monitors aus erfolgt
Fenster. Wenn Sie einen Monitor über Ihrem Hauptmonitor haben, müssen Sie
Verwenden Sie ein Negativ offset_y Wert, um die Region auf diesen Monitor zu verschieben.
IEC61883
FireWire DV/HDV-Eingabegerät mit libiec61883.
Um dieses Eingabegerät zu aktivieren, müssen Sie libiec61883, libraw1394 und libavc1394 installiert haben auf
dein System. Verwenden Sie die Konfigurationsoption "--enable-libiec61883", um mit dem Gerät zu kompilieren
aktiviert.
Das Aufnahmegerät iec61883 unterstützt die Aufnahme von einem Videogerät, das über IEEE1394 . angeschlossen ist
(FireWire), unter Verwendung von libiec61883 und dem neuen Linux FireWire-Stack (juju). Dies ist die Standardeinstellung
DV/HDV-Eingabemethode in Linux-Kernel 2.6.37 und höher, da der alte FireWire-Stack war
entfernt.
Geben Sie den FireWire-Port an, der als Eingabedatei verwendet werden soll, oder "auto", um den ersten Port auszuwählen
in Verbindung gebracht.
Optionen
dvtyp
Überschreiben Sie die automatische Erkennung von DV/HDV. Dies sollte nur verwendet werden, wenn die automatische Erkennung dies nicht tut
arbeiten oder die Verwendung eines anderen Gerätetyps untersagt werden soll. Behandlung eines DV
Gerät als HDV HDV im Glossar erklärt (oder umgekehrt) funktioniert nicht und führt zu undefiniertem Verhalten. Die
Werte Auto, dv und HDV unterstützt.
DV-Puffer
Legen Sie die maximale Puffergröße für eingehende Daten in Frames fest. Für DV ist dies ein genaues
Wert. Bei HDV ist es nicht framegenau, da HDV keine feste Bildgröße hat.
dvguid
Wählen Sie das Aufnahmegerät aus, indem Sie seine GUID angeben. Die Aufnahme wird nur durchgeführt
vom angegebenen Gerät und schlägt fehl, wenn kein Gerät mit der angegebenen GUID gefunden wird. Das ist
sinnvoll, um den Eingang auszuwählen, wenn mehrere Geräte gleichzeitig angeschlossen sind. Aussehen
unter /sys/bus/firewire/devices, um die GUIDs herauszufinden.
Beispiele
· Nehmen Sie den Eingang eines FireWire DV/HDV-Geräts auf und zeigen Sie ihn an.
ffplay -f iec61883 -i automatisch
· Nehmen Sie den Eingang eines FireWire DV/HDV-Geräts mit einem Paketpuffer von 100000 . auf und nehmen Sie ihn auf
Pakete, wenn die Quelle HDV ist.
ffmpeg -f iec61883 -i auto -hdvbuffer 100000 aus.mpg
Jack
JACK-Eingabegerät.
Um dieses Eingabegerät während der Konfiguration zu aktivieren, muss libjack auf Ihrem
System funktionieren.
Ein JACK-Eingabegerät erstellt einen oder mehrere JACK-beschreibbare Clients, einen für jeden Audiokanal,
mit name Kundenname:Eingang_N, Wobei Kundenname ist der von der Anwendung bereitgestellte Name,
und N ist eine Nummer, die den Kanal identifiziert. Jeder beschreibbare Client sendet die
erfassten Daten an das FFmpeg-Eingabegerät.
Nachdem Sie einen oder mehrere JACK-lesbare Clients erstellt haben, müssen Sie diese mit einem verbinden
oder mehr JACK-beschreibbare Clients.
Um JACK-Clients zu verbinden oder zu trennen, können Sie die jack_connect und jack_disconnect
Programme, oder tun Sie es über eine grafische Oberfläche, zum Beispiel mit qjackctl.
Um die JACK-Clients und ihre Eigenschaften aufzulisten, können Sie den Befehl aufrufen jack_lsp.
Folgt einem Beispiel, das zeigt, wie man einen JACK-lesbaren Client mit erfasst ffmpeg.
# Erstellen Sie einen JACK-beschreibbaren Client mit dem Namen "ffmpeg".
$ ffmpeg -f jack -i ffmpeg -y aus.wav
# Starten Sie den lesbaren Beispielclient jack_metro.
$ jack_metro -b 120 -d 0.2 -f 4000
# Listet die aktuellen JACK-Clients auf.
$ jack_lsp -c
system:capture_1
system:capture_2
System:Wiedergabe_1
System:Wiedergabe_2
ffmpeg:input_1
U-Bahn:120_bpm
# Verbinden Sie Metro mit dem beschreibbaren ffmpeg-Client.
$ jack_connect metro:120_bpm ffmpeg:input_1
Für weitere Informationen lesen Sie:http://jackaudio.org/>
Optionen
Kanäle
Stellen Sie die Anzahl der Kanäle ein. Standard ist 2.
lafi
Libavfilter virtuelles Eingabegerät.
Dieses Eingabegerät liest Daten von den offenen Ausgabepads eines libavfilter-Filtergraphen.
Für jede geöffnete Ausgabe des Filtergraphen erstellt das Eingabegerät einen entsprechenden Stream
die der generierten Ausgabe zugeordnet wird. Derzeit werden nur Videodaten unterstützt. Die
filtergraph wird durch die Option angegeben Graph.
Optionen
Graph
Geben Sie das als Eingabe zu verwendende Filterdiagramm an. Jeder geöffnete Videoausgang muss mit einem gekennzeichnet sein
eindeutiger String der Form "outN", wo N ist eine Zahl, die bei 0 beginnt und entspricht
der vom Gerät generierte zugeordnete Eingabestrom. Die erste unbeschriftete Ausgabe ist
automatisch dem Label "out0" zugewiesen, aber alle anderen müssen angegeben werden
ausdrücklich.
Das Suffix "+subcc" kann an das Ausgabelabel angehängt werden, um einen zusätzlichen Stream mit zu erstellen
die an diese Ausgabe angehängten Untertitelpakete (experimentell; nur für EIA-608 /
CEA-708 vorerst). Die Subcc-Streams werden nach allen normalen Streams erstellt, im
Reihenfolge des entsprechenden Streams. Wenn beispielsweise "out19+subcc" vorhanden ist,
"out7+subcc" und bis "out42" ist der Stream #43 subcc für Stream #7 und Stream #44
ist subcc für Stream #19.
Wenn nicht angegeben, wird standardmäßig der für das Eingabegerät angegebene Dateiname verwendet.
graph_file
Legen Sie den Dateinamen des Filtergraphen fest, der gelesen und an die anderen Filter gesendet werden soll. Syntax
des Filtergraphen ist derselbe wie der durch die Option spezifizierte Graph.
Dumpgraph
Diagramm nach stderr ausgeben.
Beispiele
· Erstellen Sie einen Farbvideostream und geben Sie ihn wieder mit ffplay:
ffplay -f lavfi -graph "color=c=pink [out0]" dummy
· Wie im vorherigen Beispiel, aber verwenden Sie den Dateinamen zur Angabe der Diagrammbeschreibung und
Lassen Sie das Label "out0" weg:
ffplay -f lavfi color=c=pink
· Erstellen Sie drei verschiedene Video-Test-gefilterte Quellen und spielen Sie sie ab:
ffplay -f lavfi -graph "testsrc [out0]; testrc,hflip [out1]; testrc,negiere [out2]" test3
· Lesen Sie einen Audiostream aus einer Datei mit der Amovie-Quelle und spielen Sie ihn mit . ab ffplay:
ffplay -f lavfi "movie=test.wav"
· Lesen Sie einen Audiostream und einen Videostream und geben Sie ihn wieder mit ffplay:
ffplay -f lavfi "movie=test.avi[out0];movie=test.wav[out1]"
· Dekodierte Frames in Bilder und Untertitel in eine Datei ausgeben (experimentell):
ffmpeg -f lavfi -i "movie=test.ts[out0+subcc]" -map v frame%08d.png -map s -c kopieren -f rawvideo subcc.bin
libcdio
Audio-CD-Eingabegerät basierend auf libcdio.
Um dieses Eingabegerät während der Konfiguration zu aktivieren, muss libcdio auf Ihrem
System. Es erfordert die Konfigurationsoption "--enable-libcdio".
Dieses Gerät ermöglicht das Abspielen und Aufnehmen von einer Audio-CD.
Zum Beispiel zum Kopieren mit ffmpeg die gesamte Audio-CD in / dev / sr0, können Sie den Befehl ausführen:
ffmpeg -f libcdio -i /dev/sr0 cd.wav
Optionen
Geschwindigkeit
Legen Sie die Lesegeschwindigkeit des Laufwerks fest. Der Standardwert ist 0.
Die Geschwindigkeit wird in CD-ROM-Geschwindigkeitseinheiten angegeben. Die Geschwindigkeit wird über die libcdio . eingestellt
Funktion "cdio_cddap_speed_set". Bei vielen CD-ROM-Laufwerken wird ein zu großer Wert angegeben
führt zur Verwendung der schnellsten Geschwindigkeit.
paranoia_mode
Setzen Sie Flags für den Paranoia-Wiederherstellungsmodus. Es akzeptiert einen der folgenden Werte:
deaktivieren
überprüfen
überlappen
nie überspringen
voller
Standardwert ist deaktivieren.
Weitere Informationen zu den verfügbaren Wiederherstellungsmodi finden Sie im Paranoia-Projekt
Dokumentation.
libdc1394
IIDC1394-Eingabegerät, basierend auf libdc1394 und libraw1394.
Erfordert die Konfigurationsoption "--enable-libdc1394".
Eröffnung
Das OpenAL-Eingabegerät bietet Audioaufnahme auf allen Systemen mit einem funktionierenden OpenAL 1.1
Umsetzung.
Um dieses Eingabegerät während der Konfiguration zu aktivieren, benötigen Sie OpenAL-Header und -Bibliotheken
auf Ihrem System installiert und müssen FFmpeg mit "--enable-openal" konfigurieren.
OpenAL-Header und -Bibliotheken sollten als Teil Ihrer OpenAL-Implementierung bereitgestellt werden, oder
als zusätzlicher Download (ein SDK). Abhängig von Ihrer Installation müssen Sie möglicherweise angeben
zusätzliche Flags über die "--extra-cflags" und "--extra-ldflags" um den Build zuzulassen
System, um die OpenAL-Header und -Bibliotheken zu finden.
Es folgt eine unvollständige Liste von OpenAL-Implementierungen:
Grüne Energie
Die offizielle Windows-Implementierung, die Hardwarebeschleunigung mit unterstütztem
Geräte- und Software-Fallback. Sehenhttp://openal.org/>.
OpenAL SOFT
Implementierung von portabler Open-Source-Software (LGPL). Enthält Back-Ends für die meisten
allgemeine Sound-APIs auf den Betriebssystemen Windows, Linux, Solaris und BSD. Sehen
<http://kcat.strangesoft.net/openal.html>.
Apple
OpenAL ist Teil von Core Audio, dem offiziellen Audio-Interface von Mac OS X. Sehen
<http://developer.apple.com/technologies/mac/audio-and-video.html>
Dieses Gerät ermöglicht die Aufnahme von einem Audioeingabegerät, das über OpenAL verwaltet wird.
Sie müssen den Namen des zu erfassenden Geräts im angegebenen Dateinamen angeben. Wenn die
eine leere Zeichenfolge bereitgestellt wird, wählt das Gerät automatisch das Standardgerät aus. Du kannst
erhalten Sie die Liste der unterstützten Geräte, indem Sie die Option verwenden list_devices.
Optionen
Kanäle
Legen Sie die Anzahl der Kanäle im aufgenommenen Audio fest. Nur die Werte 1 (monaural) und 2
(Stereo) werden derzeit unterstützt. Standardmäßig auf 2.
Beispielgröße
Legen Sie die Sample-Größe (in Bit) des aufgenommenen Audios fest. Nur die Werte 8 und 16 sind
derzeit unterstützt. Standardmäßig auf 16.
Beispielrate
Stellen Sie die Abtastrate (in Hz) des aufgenommenen Audios ein. Standardmäßig auf 44.1K.
list_devices
Wenn auf was immer dies auch sein sollte., eine Geräteliste drucken und beenden. Standardmäßig auf falsch.
Beispiele
Drucken Sie die Liste der von OpenAL unterstützten Geräte und beenden Sie:
$ ffmpeg -list_devices true -f openal -i dummy out.ogg
Aufnahme vom OpenAL-Gerät DR-BT101 Pulseaudio:
$ ffmpeg -f openal -i 'DR-BT101 über PulseAudio' out.ogg
Aufnahme vom Standardgerät (beachten Sie die leere Zeichenfolge '' als Dateiname):
$ ffmpeg -f openal -i ''out.ogg
Aufnehmen von zwei Geräten gleichzeitig, Schreiben in zwei verschiedene Dateien innerhalb desselben
ffmpeg Befehl:
$ ffmpeg -f openal -i 'DR-BT101 über PulseAudio' out1.ogg -f openal -i 'ALSA Default' out2.ogg
Hinweis: Nicht alle OpenAL-Implementierungen unterstützen mehrere gleichzeitige Erfassungen - versuchen Sie die
neueste OpenAL Soft, wenn das obige nicht funktioniert.
Zentrum
Öffnen Sie das Sound System-Eingabegerät.
Der dem Eingabegerät bereitzustellende Dateiname ist der Geräteknoten, der die OSS-Eingabe repräsentiert
Gerät und ist normalerweise auf eingestellt /dev/dsp.
Zum Beispiel zum Greifen von /dev/dsp Verwendung von ffmpeg Verwenden Sie den Befehl:
ffmpeg -f oss -i /dev/dsp /tmp/oss.wav
Weitere Informationen zu OSS finden Sie unter:http://manuals.opensound.com/usersguide/dsp.html>
Optionen
Beispielrate
Stellen Sie die Abtastrate in Hz ein. Der Standardwert ist 48000.
Kanäle
Stellen Sie die Anzahl der Kanäle ein. Standard ist 2.
Puls
PulseAudio-Eingabegerät.
Um dieses Ausgabegerät zu aktivieren, müssen Sie FFmpeg mit "--enable-libpulse" konfigurieren.
Der dem Eingabegerät bereitzustellende Dateiname ist ein Quellgerät oder die Zeichenfolge "default".
Um die PulseAudio-Quellgeräte und ihre Eigenschaften aufzulisten, können Sie den Befehl aufrufen
paktl Liste Quellen.
Weitere Informationen zu PulseAudio finden Sie aufhttp://www.pulseaudio.org>.
Optionen
Server
Stellen Sie eine Verbindung zu einem bestimmten PulseAudio-Server her, der durch eine IP-Adresse angegeben wird. Standardserver
wird verwendet, wenn nicht bereitgestellt.
Name
Geben Sie den Anwendungsnamen an, den PulseAudio verwendet, wenn aktive Clients angezeigt werden, durch
Standardmäßig ist es der String "LIBAVFORMAT_IDENT".
Streamname
Geben Sie den Stream-Namen an, den PulseAudio verwendet, wenn aktive Streams angezeigt werden, standardmäßig ist es
ist "Aufzeichnung".
Beispielrate
Geben Sie die Samplerate in Hz an, standardmäßig werden 48kHz verwendet.
Kanäle
Geben Sie die verwendeten Kanäle an, standardmäßig ist 2 (Stereo) eingestellt.
Rahmengröße
Geben Sie die Anzahl der Bytes pro Frame an, standardmäßig ist sie auf 1024 eingestellt.
fragment_size
Geben Sie das minimale Pufferungsfragment in PulseAudio an, es wirkt sich auf das Audio aus
Latenz. Standardmäßig ist es nicht eingestellt.
Wanduhr
Stellen Sie den anfänglichen PTS mit der aktuellen Uhrzeit ein. Standard ist 1.
Beispiele
Zeichnen Sie einen Stream vom Standardgerät auf:
ffmpeg -f Pulse -i Standard /tmp/pulse.wav
qtkit
QTKit-Eingabegerät.
Der als Eingabe übergebene Dateiname wird so geparst, dass er entweder einen Gerätenamen oder einen Index enthält. Die
Geräteindex kann auch mit -video_device_index angegeben werden. Ein gegebener Geräteindex wird
einen beliebigen Gerätenamen überschreiben. Wenn das gewünschte Gerät nur aus Zahlen besteht, verwenden Sie
-video_device_index, um es zu identifizieren. Das Standardgerät wird gewählt, wenn eine leere Zeichenfolge
oder es wird der Gerätename "default" vergeben. Die verfügbaren Geräte können mit aufgezählt werden
-list_devices.
ffmpeg -f qtkit -i "0" out.mpg
ffmpeg -f qtkit -video_device_index 0 -i "" out.mpg
ffmpeg -f qtkit -i "default" out.mpg
ffmpeg -f qtkit -list_devices true -i ""
Optionen
Bildrate
Bildrate einstellen. Standard ist 30.
list_devices
Wenn auf "true" gesetzt, drucken Sie eine Liste der Geräte und beenden Sie das Programm. Standard ist "false".
video_device_index
Wählen Sie das Videogerät nach dem Index für Geräte mit demselben Namen aus (beginnt bei 0).
sndio
sndio-Eingabegerät.
Um dieses Eingabegerät während der Konfiguration zu aktivieren, muss libsndio auf Ihrem
System funktionieren.
Der dem Eingabegerät bereitzustellende Dateiname ist der Geräteknoten, der das sndio . repräsentiert
Eingabegerät und ist normalerweise auf eingestellt /dev/audio0.
Zum Beispiel zum Greifen von /dev/audio0 Verwendung von ffmpeg Verwenden Sie den Befehl:
ffmpeg -f sndio -i /dev/audio0 /tmp/oss.wav
Optionen
Beispielrate
Stellen Sie die Abtastrate in Hz ein. Der Standardwert ist 48000.
Kanäle
Stellen Sie die Anzahl der Kanäle ein. Standard ist 2.
video4linux2, v4l2
Video4Linux2-Eingangsvideogerät.
"v4l2" kann als Alias für "video4linux2" verwendet werden.
Wenn FFmpeg mit v4l-utils-Unterstützung erstellt wurde (mithilfe der "--enable-libv4l2"-Konfiguration
Option), ist es möglich, sie mit der Eingabegeräteoption "-use_libv4l2" zu verwenden.
Der Name des zu greifenden Geräts ist ein Dateigeräteknoten, normalerweise neigen Linux-Systeme dazu
automatisch solche Knoten erstellen, wenn das Gerät (z. B. eine USB-Webcam) an die
System und hat einen Namen der Art /dev/videoN, Wobei N ist eine Zahl, die mit dem verbunden ist
Gerät.
Video4Linux2-Geräte unterstützen normalerweise eine begrenzte Anzahl von BreitexHöhe Größen und Bildraten.
Sie können überprüfen, welche unterstützt werden mit -list_formats alle für Video4Linux2-Geräte. Etwas
Geräte wie TV-Karten unterstützen einen oder mehrere Standards. Es ist möglich, alle aufzulisten
unterstützte Standards mit -list_standards alle.
Die Zeitbasis für die Zeitstempel beträgt 1 Mikrosekunde. Abhängig von der Kernel-Version und
Konfiguration können die Zeitstempel von der Echtzeituhr abgeleitet werden (Ursprung am Unix
Epoche) oder die monotone Uhr (Ursprung in der Regel beim Booten, unbeeinflusst von NTP oder manuell
Änderungen an der Uhr). Die -Zeitstempel abs or -ts abs Option kann verwendet werden, um zu erzwingen
Umwandlung in die Echtzeituhr.
Einige Anwendungsbeispiele des video4linux2-Geräts mit ffmpeg und ffplay:
· Liste der unterstützten Formate für ein video4linux2-Gerät auf:
ffplay -f video4linux2 -list_formats all /dev/video0
· Nehmen Sie den Eingang eines video4linux2-Geräts auf und zeigen Sie ihn an:
ffplay -f video4linux2 -framerate 30 -video_size hd720 /dev/video0
· Nehmen Sie den Eingang eines video4linux2-Geräts auf und zeichnen Sie ihn auf, belassen Sie die Bildrate und -größe als
vorher eingestellt:
ffmpeg -f video4linux2 -input_format mjpeg -i /dev/video0 out.mpeg
Weitere Informationen zu Video4Linux finden Sie unterhttp://linuxtv.org/>.
Optionen
Standard
Setzen Sie den Standard. Muss der Name eines unterstützten Standards sein. Um eine Liste der zu erhalten
unterstützten Standards, verwenden Sie die list_standards .
Kanal
Stellen Sie die Eingangskanalnummer ein. Standardwert -1, d. h. die Verwendung des zuvor ausgewählten
Kanal.
Video Größe
Stellen Sie die Videobildgröße ein. Das Argument muss ein String in der Form sein WIDTHxHEIGHT oder eine
gültige Größenabkürzung.
Pixelformat
Wählen Sie das Pixelformat (gilt nur für Raw-Video-Eingabe).
Eingabeformat
Legen Sie das bevorzugte Pixelformat (für RAW-Video) oder einen Codec-Namen fest. Diese Option ermöglicht
eine, um das Eingabeformat auszuwählen, wenn mehrere verfügbar sind.
Framerate
Stellen Sie die bevorzugte Videobildrate ein.
Listenformate
Listen Sie die verfügbaren Formate auf (unterstützte Pixelformate, Codecs und Bildgrößen) und beenden Sie.
Verfügbare Werte sind:
alle Alle verfügbaren (komprimierten und nicht komprimierten) Formate anzeigen.
roh Nur Rohvideoformate (nicht komprimiert) anzeigen.
Druckluft
Nur komprimierte Formate anzeigen.
list_standards
Unterstützte Standards auflisten und beenden.
Verfügbare Werte sind:
alle Alle unterstützten Standards anzeigen.
Zeitstempel, ts
Legen Sie die Art der Zeitstempel für erfasste Frames fest.
Verfügbare Werte sind:
Standard
Verwenden Sie Zeitstempel aus dem Kernel.
abs Verwenden Sie absolute Zeitstempel (Wanduhr).
mono2abs
Erzwingen Sie die Umwandlung von monotonen in absolute Zeitstempel.
Der Standardwert ist "Standard".
use_libv4l2
Verwenden Sie die Konvertierungsfunktionen von libv4l2 (v4l-utils). Standard ist 0.
vfwcap
VfW-Aufnahmegerät (Video für Windows).
Der als Eingabe übergebene Dateiname ist die Nummer des Capture-Treibers im Bereich von 0 bis 9. Sie können
Verwenden Sie "list" als Dateinamen, um eine Liste von Treibern zu drucken. Jeder andere Dateiname wird interpretiert
als Gerätenummer 0.
Optionen
Video Größe
Stellen Sie die Videobildgröße ein.
Framerate
Stellen Sie die Aufnahme-Bildrate ein. Der Standardwert ist "ntsc", entsprechend einer Bildrate von
"30000/1001".
x11grab
X11-Videoeingabegerät.
Um dieses Eingabegerät während der Konfiguration zu aktivieren, muss libxcb auf Ihrem System installiert sein.
Es wird während der Konfiguration automatisch erkannt.
Alternativ die Konfigurationsoption --enable-x11grab existiert für ältere Xlib-Benutzer.
Mit diesem Gerät kann man einen Bereich eines X11-Displays erfassen.
Der als Eingabe übergebene Dateiname hat die Syntax:
[ ]: . [+ , ]
hostname:Anzeige_Nummer.Bildschirmnummer gibt den X11-Anzeigenamen des zu erfassenden Bildschirms an
von. hostname kann weggelassen werden und ist standardmäßig "localhost". Die Umgebungsvariable
DISPLAY enthält den Standardanzeigenamen.
x_offset und y_offset Geben Sie die Versätze des erfassten Bereichs in Bezug auf oben links an
Rand des X11-Bildschirms. Sie sind standardmäßig auf 0 eingestellt.
Überprüfen Sie die X11-Dokumentation (zB Mann X) für nähere Informationen.
Verwenden Sie das xdpyinfo Programm zum Abrufen grundlegender Informationen über die Eigenschaften Ihres X11
Anzeige (zB grep für "Name" oder "Dimensionen").
Zum Beispiel zum Greifen von : 0.0 Verwendung von ffmpeg:
ffmpeg -f x11grab -framerate 25 -video_size cif -i :0.0 out.mpg
Greifen Sie an Position "10,20":
ffmpeg -f x11grab -framerate 25 -video_size cif -i :0.0+10,20 out.mpg
Optionen
draw_mouse
Geben Sie an, ob der Mauszeiger gezeichnet werden soll. Ein Wert von 0 gibt an, dass nicht gezeichnet wird
Zeiger. Der Standardwert ist 1.
follow_mouse
Lassen Sie den erfassten Bereich der Maus folgen. Das Argument kann "zentriert" sein oder eine Anzahl von
Pixel PIXEL.
Bei Angabe von "centered" folgt der Greifbereich dem Mauszeiger
und hält den Zeiger in der Mitte der Region; andernfalls folgt die Region nur, wenn
der Mauszeiger reicht hinein PIXEL (größer als Null) zum Rand der Region.
Beispielsweise:
ffmpeg -f x11grab -follow_mouse zentriert -framerate 25 -video_size cif -i :0.0 out.mpg
Nur folgen, wenn der Mauszeiger innerhalb von 100 Pixeln bis zum Rand reicht:
ffmpeg -f x11grab -follow_mouse 100 -framerate 25 -video_size cif -i :0.0 out.mpg
Framerate
Stellen Sie die Aufnahme-Bildrate ein. Der Standardwert ist "ntsc", entsprechend einer Bildrate von
"30000/1001".
show_region
Zeigen Sie den erfassten Bereich auf dem Bildschirm an.
If show_region mit 1 angegeben ist, dann wird die Greifregion angezeigt auf
Bildschirm. Mit dieser Option ist es leicht zu wissen, was gegriffen wird, wenn nur eine Portion
des Bildschirms gegriffen wird.
region_border
Legen Sie die Dicke der Regionsgrenze fest, wenn -show_region 1 wird genutzt. Bereich ist 1 bis 128 und
Standard ist 3 (nur XCB-basiertes x11grab).
Beispielsweise:
ffmpeg -f x11grab -show_region 1 -framerate 25 -video_size cif -i :0.0+10,20 out.mpg
Mit follow_mouse:
ffmpeg -f x11grab -follow_mouse zentriert -show_region 1 -framerate 25 -video_size cif -i :0.0 out.mpg
Video Größe
Stellen Sie die Videobildgröße ein. Der Standardwert ist "vga".
use_shm
Verwenden Sie die MIT-SHM-Erweiterung für Shared Memory. Der Standardwert ist 1. Es kann erforderlich sein
um es für Remote-Displays zu deaktivieren (nur Legacy x11grab).
grab_x grab_y AVOption
Die Syntax lautet:
-grab_x -grab_y
Legen Sie die Koordinaten der Greifregion fest. Sie werden als Versatz von der oberen linken Ecke ausgedrückt
des X11-Fensters. Der Standardwert ist 0.
AUSGABE GERÄTE
Ausgabegeräte sind konfigurierte Elemente in FFmpeg, die Multimediadaten in ein
Ausgabegerät, das an Ihr System angeschlossen ist.
Wenn Sie Ihren FFmpeg-Build konfigurieren, werden alle unterstützten Ausgabegeräte aktiviert durch
Ursprünglich. Sie können alle verfügbaren auflisten, indem Sie die Konfigurationsoption "--list-outdevs" verwenden.
Sie können alle Ausgabegeräte mit der Konfigurationsoption "--disable-outdevs" deaktivieren und
Aktivieren Sie selektiv ein Ausgabegerät mit der Option "--enable-outdev=OUTDEV", oder du kannst
deaktivieren Sie ein bestimmtes Eingabegerät mit der Option "--disable-outdev=OUTDEV".
Die Option "-devices" des ff*-Tools zeigt die Liste der aktivierten Ausgabegeräte an.
Es folgt eine Beschreibung der derzeit verfügbaren Ausgabegeräte.
auch
ALSA-Ausgabegerät (Advanced Linux Sound Architecture).
Beispiele
· Spielen Sie eine Datei auf einem standardmäßigen ALSA-Gerät ab:
ffmpeg -i INPUT -f als Standard
· Spielen Sie eine Datei auf Soundkarte 1, Audiogerät 7 ab:
ffmpeg -i INPUT -f alsa hw:1,7
caca
CACA-Ausgabegerät.
Dieses Ausgabegerät ermöglicht die Anzeige eines Videostreams im CACA-Fenster. Nur ein CACA-Fenster
ist pro Anwendung erlaubt, Sie können also nur eine Instanz dieses Ausgabegeräts in einem
Anwendung.
Um dieses Ausgabegerät zu aktivieren, müssen Sie FFmpeg mit "--enable-libcaca" konfigurieren.
libcaca ist eine Grafikbibliothek, die Text anstelle von Pixeln ausgibt.
Weitere Informationen zu libcaca finden Sie unter:http://caca.zoy.org/wiki/libcaca>
Optionen
Fenstertitel
Setzen Sie den CACA-Fenstertitel, falls nicht angegeben, standardmäßig auf den Dateinamen, der für das
Ausgabegerät.
Fenstergröße
Legen Sie die CACA-Fenstergröße fest, kann eine Zeichenfolge der Form sein BreitexHöhe oder eine Videogröße
Abkürzung. Wenn nicht angegeben, wird standardmäßig die Größe des Eingangsvideos verwendet.
Fahrer
Bildschirmtreiber einstellen.
Algorithmus
Dithering-Algorithmus einstellen. Dithering ist notwendig, weil das gerenderte Bild
normalerweise weit mehr Farben als die verfügbare Palette. Die akzeptierten Werte sind aufgelistet
mit "-list_dither-Algorithmen".
Antialiasing
Legen Sie die Antialiasing-Methode fest. Antialiasing glättet das gerenderte Bild und vermeidet die
häufig gesehener Treppeneffekt. Die akzeptierten Werte werden mit "-list_dither . aufgelistet
Antialiase".
charset
Legen Sie fest, welche Zeichen beim Rendern von Text verwendet werden sollen. Die akzeptierten Werte
werden mit "-list_dither charsets" aufgelistet.
Farbe
Legen Sie die Farbe fest, die beim Rendern von Text verwendet werden soll. Die akzeptierten Werte sind mit . aufgeführt
"-list_dither-Farben".
list_drivers
Wenn auf was immer dies auch sein sollte., eine Liste der verfügbaren Treiber drucken und beenden.
list_dither
Listet die verfügbaren Dither-Optionen in Bezug auf das Argument auf. Das Argument muss eines von . sein
"Algorithmen", "Antialiase", "Zeichensätze", "Farben".
Beispiele
· Der folgende Befehl zeigt die ffmpeg Die Ausgabe ist ein CACA-Fenster, das seine Größe auf . erzwingt
80x25:
ffmpeg -i INPUT -vcodec rawvideo -pix_fmt rgb24 -window_size 80x25 -f caca -
· Liste der verfügbaren Treiber anzeigen und beenden:
ffmpeg -i INPUT -pix_fmt rgb24 -f caca -list_drivers true -
· Liste der verfügbaren Dither-Farben anzeigen und beenden:
ffmpeg -i INPUT -pix_fmt rgb24 -f caca -list_dither Farben -
Decklink
Das Decklink-Ausgabegerät bietet Wiedergabefunktionen für Blackmagic DeckLink-Geräte.
Um dieses Ausgabegerät zu aktivieren, benötigen Sie das Blackmagic DeckLink SDK und Sie müssen
mit den entsprechenden "--extra-cflags" und "--extra-ldflags" konfigurieren. Unter Windows können Sie
müssen die IDL-Dateien durchlaufen frei.
DeckLink ist bei den unterstützten Formaten sehr wählerisch. Pixelformat ist immer uyvy422,
Bildrate und Videogröße müssen für Ihr Gerät mit ermittelt werden -list_formats 1. Audio
Die Abtastrate beträgt immer 48 kHz.
Optionen
list_devices
Wenn auf was immer dies auch sein sollte., eine Geräteliste drucken und beenden. Standardmäßig auf falsch.
Listenformate
Wenn auf was immer dies auch sein sollte., eine Liste der unterstützten Formate drucken und beenden. Standardmäßig auf falsch.
Vorlauf
Zeit zum Vorabrollen des Videos in Sekunden. Standardmäßig auf 0.5.
Beispiele
· Ausgabegeräte auflisten:
ffmpeg -i test.avi -f decklink -list_devices 1 Dummy
· Liste unterstützter Formate:
ffmpeg -i test.avi -f decklink -list_formats 1 'DeckLink Mini Monitor'
· Videoclip abspielen:
ffmpeg -i test.avi -f decklink -pix_fmt uyvy422 'DeckLink Mini-Monitor'
· Videoclip mit nicht standardmäßiger Framerate oder Videogröße abspielen:
ffmpeg -i test.avi -f decklink -pix_fmt uyvy422 -s 720x486 -r 24000/1001 'DeckLink Mini Monitor'
fbdev
Ausgabegerät für Linux-Framebuffer.
Der Linux-Framebuffer ist eine von der Grafikhardware unabhängige Abstraktionsschicht zum Anzeigen von Grafiken
auf einem Computermonitor, normalerweise auf der Konsole. Der Zugriff erfolgt über ein Dateigerät
Knoten, normalerweise /dev/fb0.
Für genauere Informationen lesen Sie die Datei Dokumentation/fb/framebuffer.txt enthalten in
den Linux-Quellbaum.
Optionen
xoffset
yoffset
Legen Sie die x/y-Koordinate der oberen linken Ecke fest. Standard ist 0.
Beispiele
Spielen Sie eine Datei auf einem Framebuffer-Gerät ab /dev/fb0. Erforderliches Pixelformat ist abhängig vom aktuellen
Framebuffer-Einstellungen.
ffmpeg -re -i INPUT -vcodec rawvideo -pix_fmt bgra -f fbdev /dev/fb0
Siehe auchhttp://linux-fbdev.sourceforge.net/>, und fbset(1).
opengl
OpenGL-Ausgabegerät.
Um dieses Ausgabegerät zu aktivieren, müssen Sie FFmpeg mit "--enable-opengl" konfigurieren.
Dieses Ausgabegerät ermöglicht das Rendern im OpenGL-Kontext. Kontext kann bereitgestellt werden von
Anwendungs- oder Standard-SDL-Fenster wird erstellt.
Wenn das Gerät in einen externen Kontext rendert, muss die Anwendung Handler für Folgendes implementieren
Nachrichten: "AV_DEV_TO_APP_CREATE_WINDOW_BUFFER" - OpenGL-Kontext im aktuellen Thread erstellen.
"AV_DEV_TO_APP_PREPARE_WINDOW_BUFFER" - OpenGL-Kontext aktuell machen.
"AV_DEV_TO_APP_DISPLAY_WINDOW_BUFFER" - Puffer tauschen.
"AV_DEV_TO_APP_DESTROY_WINDOW_BUFFER" - Zerstöre den OpenGL-Kontext. Bewerbung ist auch
erforderlich, um ein Gerät durch Senden über die aktuelle Auflösung zu informieren
Meldung "AV_APP_TO_DEV_WINDOW_SIZE".
Optionen
Hintergrund
Hintergrundfarbe einstellen. Schwarz ist eine Standardeinstellung.
kein_fenster
Deaktiviert das Standard-SDL-Fenster, wenn es auf einen Wert ungleich Null gesetzt ist. Bewerbung muss angegeben werden
OpenGL-Kontext und sowohl "window_size_cb"- als auch "window_swap_buffers_cb"-Callbacks, wenn
gesetzt.
Fenstertitel
Setzt den SDL-Fenstertitel, falls nicht angegeben, standardmäßig auf den Dateinamen, der für die
Ausgabegerät. Ignoriert, wenn kein_fenster wird gesetzt.
Fenstergröße
Legen Sie die bevorzugte Fenstergröße fest, kann eine Zeichenfolge der Form widthxheight oder eine Videogröße sein
Abkürzung. Wenn nicht angegeben, wird standardmäßig die Größe des Eingangsvideos verwendet, herunterskaliert
nach dem Seitenverhältnis. Meist verwendbar, wenn kein_fenster ist nicht gesetzt.
Beispiele
Spielen Sie eine Datei im SDL-Fenster mit OpenGL-Rendering ab:
ffmpeg -i INPUT -f opengl "Fenstertitel"
Zentrum
OSS (Open Sound System) Ausgabegerät.
Puls
PulseAudio-Ausgabegerät.
Um dieses Ausgabegerät zu aktivieren, müssen Sie FFmpeg mit "--enable-libpulse" konfigurieren.
Weitere Informationen zu PulseAudio finden Sie aufhttp://www.pulseaudio.org>
Optionen
Server
Stellen Sie eine Verbindung zu einem bestimmten PulseAudio-Server her, der durch eine IP-Adresse angegeben wird. Standardserver
wird verwendet, wenn nicht bereitgestellt.
Name
Geben Sie den Anwendungsnamen an, den PulseAudio verwendet, wenn aktive Clients angezeigt werden, durch
Standardmäßig ist es der String "LIBAVFORMAT_IDENT".
Streamname
Geben Sie den Stream-Namen an, den PulseAudio verwendet, wenn aktive Streams angezeigt werden, standardmäßig ist es
wird auf den angegebenen Ausgabenamen gesetzt.
Gerät
Geben Sie das zu verwendende Gerät an. Standardgerät wird verwendet, wenn es nicht bereitgestellt wird. Liste der Ausgaben
Geräte können mit Befehl abgerufen werden paktl Liste Senken.
Puffergröße
Puffer_Dauer
Steuern Sie die Größe und Dauer des PulseAudio-Puffers. Ein kleiner Puffer gibt mehr
Kontrolle, erfordert aber häufigere Updates.
Puffergröße gibt die Größe in Byte an, während Puffer_Dauer gibt Dauer in . an
Millisekunden.
Wenn beide Optionen angegeben sind, wird der höchste Wert verwendet (Dauer ist
mithilfe von Stream-Parametern in Byte umgerechnet). Wenn sie auf 0 gesetzt sind (was
default), verwendet das Gerät den Standardwert für die PulseAudio-Dauer. Standardmäßig
PulseAudio hat die Pufferdauer auf etwa 2 Sekunden eingestellt.
vorbuf
Geben Sie die Größe der Vorpufferung in Bytes an. Der Server startet nicht mit der Wiedergabe vor at
am wenigsten vorbuf Bytes stehen im Puffer zur Verfügung. Standardmäßig ist diese Option initialisiert
auf den gleichen Wert wie Puffergröße or Puffer_Dauer (je nachdem, was größer ist).
minerf
Geben Sie die Mindestanforderungsgröße in Byte an. Der Server fordert nicht weniger als . an minerf
Bytes vom Client, wartet stattdessen, bis der Puffer frei genug ist, um mehr anzufordern
Byte auf einmal. Es wird empfohlen, diese Option nicht zu setzen, da dies zu initialisiert wird
ein Wert, der vom Server als sinnvoll erachtet wird.
Beispiele
Spielen Sie eine Datei auf dem Standardgerät auf dem Standardserver ab:
ffmpeg -i INPUT -f pulse "Streamname"
sdl
SDL-Ausgabegerät (Simple DirectMedia Layer).
Dieses Ausgabegerät ermöglicht die Anzeige eines Videostreams in einem SDL-Fenster. Nur ein SDL-Fenster
ist pro Anwendung erlaubt, Sie können also nur eine Instanz dieses Ausgabegeräts in einem
Anwendung.
Um dieses Ausgabegerät zu aktivieren, müssen Sie bei der Konfiguration libsdl auf Ihrem System installieren
dein bauen.
Weitere Informationen zu SDL finden Sie unter:http://www.libsdl.org/>
Optionen
Fenstertitel
Setzt den SDL-Fenstertitel, falls nicht angegeben, standardmäßig auf den Dateinamen, der für die
Ausgabegerät.
Symboltitel
Legen Sie den Namen des symbolisierten SDL-Fensters fest, wenn er nicht angegeben wird, wird er auf denselben Wert gesetzt
of Fenstertitel.
Fenstergröße
Legen Sie die SDL-Fenstergröße fest, kann eine Zeichenfolge der Form sein BreitexHöhe oder eine Videogröße
Abkürzung. Wenn nicht angegeben, wird standardmäßig die Größe des Eingangsvideos verwendet, herunterskaliert
nach dem Seitenverhältnis.
Fenster_Vollbild
Stellen Sie den Vollbildmodus ein, wenn ein Wert ungleich Null bereitgestellt wird. Der Standardwert ist null.
Interaktives Benutzererlebnis Befehle
Das vom Gerät erstellte Fenster kann über die folgenden interaktiven Funktionen gesteuert werden
Befehle.
q, ESC
Beenden Sie das Gerät sofort.
Beispiele
Der folgende Befehl zeigt die ffmpeg Die Ausgabe ist ein SDL-Fenster, das seine Größe auf die
qcif-Format:
ffmpeg -i INPUT -vcodec rawvideo -pix_fmt yuv420p -window_size qcif -f sdl "SDL-Ausgabe"
sndio
sndio-Audioausgabegerät.
xv
XV (XVideo) Ausgabegerät.
Dieses Ausgabegerät ermöglicht die Anzeige eines Videostreams in einem X Window System-Fenster.
Optionen
display_name
Geben Sie den Hardware-Anzeigenamen an, der die Anzeige und die Kommunikation bestimmt
Domäne verwendet werden.
Der Anzeigename oder die Umgebungsvariable DISPLAY kann ein String im Format
hostname[:Anzahl[.Bildschirmnummer]].
hostname gibt den Namen des Host-Rechners an, auf dem sich die Anzeige physisch befindet
angebracht. Anzahl gibt die Nummer des Anzeigeservers auf diesem Hostcomputer an.
Bildschirmnummer gibt den Bildschirm an, der auf diesem Server verwendet werden soll.
Wenn nicht angegeben, wird standardmäßig der Wert der Umgebungsvariablen DISPLAY verwendet.
Zum Beispiel würde "dual-headed:0.1" Bildschirm 1 der Anzeige 0 auf dem Gerät angeben
mit dem Namen ``doppelköpfig''.
Weitere Informationen zum Anzeigenamen finden Sie in der X11-Spezifikation.
Format.
window_id
Wenn ein Wert ungleich Null eingestellt ist, erstellt das Gerät kein neues Fenster, sondern verwendet vorhandene
einer mit versehen window_id. Standardmäßig ist diese Option auf Null gesetzt und das Gerät erstellt
ein eigenes Fenster.
Fenstergröße
Legen Sie die erstellte Fenstergröße fest, kann eine Zeichenfolge der Form sein BreitexHöhe oder eine Videogröße
Abkürzung. Wenn nicht angegeben, wird standardmäßig die Größe des Eingangsvideos verwendet. Ignoriert
wann window_id wird gesetzt.
Fenster_x
Fenster_y
Legen Sie die X- und Y-Fenster-Offsets für das erstellte Fenster fest. Sie werden beide von auf 0 gesetzt
Ursprünglich. Die Werte können vom Fenstermanager ignoriert werden. Ignoriert, wenn window_id is
gesetzt.
Fenstertitel
Setzt den Fenstertitel, falls nicht angegeben, standardmäßig auf den Dateinamen, der für die
Ausgabegerät. Ignoriert, wenn window_id wird gesetzt.
Weitere Informationen zu XVideo finden Sie unterhttp://www.x.org/>.
Beispiele
· Videoeingang dekodieren, anzeigen und kodieren mit ffmpeg gleichzeitig:
ffmpeg -i EINGANG AUSGANG -f xv Anzeige
· Decodieren Sie das Eingangsvideo und zeigen Sie es in mehreren X11-Fenstern an:
ffmpeg -i INPUT -f xv normal -vf negieren -f xv negiert
RESAMPLER OPTIONAL
Der Audio-Resampler unterstützt die folgenden benannten Optionen.
Optionen können eingestellt werden durch Angabe von -zu erhalten Wert in den FFmpeg-Tools, zu erhalten=Wert für die
aresample-Filter, indem Sie den Wert explizit in den "SwrContext"-Optionen setzen oder den
libavutil/opt.h API für die programmatische Verwendung.
trinken in_channel_count
Stellen Sie die Anzahl der Eingangskanäle ein. Der Standardwert ist 0. Die Einstellung dieses Wertes ist nicht
obligatorisch, wenn das entsprechende Kanallayout in_channel_layout wird gesetzt.
ach, out_channel_count
Stellen Sie die Anzahl der Ausgangskanäle ein. Der Standardwert ist 0. Die Einstellung dieses Wertes ist nicht
obligatorisch, wenn das entsprechende Kanallayout out_channel_layout wird gesetzt.
ähm, used_channel_count
Stellen Sie die Anzahl der verwendeten Eingangskanäle ein. Der Standardwert ist 0. Diese Option wird nur verwendet
für spezielle Neuzuordnung.
ist, in_sample_rate
Stellen Sie die Eingangs-Sample-Rate ein. Der Standardwert ist 0.
osr, out_sample_rate
Stellen Sie die Ausgabe-Sample-Rate ein. Der Standardwert ist 0.
ist, in_sample_fmt
Geben Sie das Eingabe-Sample-Format an. Es ist standardmäßig auf "keine" eingestellt.
osf, out_sample_fmt
Geben Sie das Ausgabe-Sample-Format an. Es ist standardmäßig auf "keine" eingestellt.
tsf, internal_sample_fmt
Stellen Sie das interne Sample-Format ein. Der Standardwert ist "keiner". Dies wird automatisch
ausgewählt, wenn es nicht explizit festgelegt ist.
ickl, in_channel_layout
ok, out_channel_layout
Legen Sie das Layout des Eingangs-/Ausgangskanals fest.
Weitere Informationen finden Sie auch in den Kanal Layout Abschnitt in ffmpeg-utils(1) manuell für die erforderliche Syntax.
Cleve, center_mix_level
Stellen Sie den Center-Mix-Pegel ein. Es ist ein in DeziBel ausgedrückter Wert und muss im
Intervall [-32,32].
slev, Surround_mix_level
Stellen Sie den Surround-Mix-Pegel ein. Es ist ein in DeziBel ausgedrückter Wert und muss im
Intervall [-32,32].
lfe_mix_level
Stellen Sie den LFE-Mix auf Nicht-LFE-Pegel ein. Wird verwendet, wenn ein LFE-Eingang vorhanden ist, aber kein LFE
Ausgang. Es ist ein in DeziBel ausgedrückter Wert und muss im Intervall [-32,32] liegen.
rmvol, rematrix_volume
Stellen Sie die Rematrix-Lautstärke ein. Der Standardwert ist 1.0.
rematrix_maxval
Legen Sie den maximalen Ausgabewert für das Rematrixing fest. Dies kann verwendet werden, um Clipping vs.
Verhindern der Lautstärkereduzierung Ein Wert von 1.0 verhindert Clipping.
Flaggen, swr_flags
Setzt Flags, die vom Konverter verwendet werden. Der Standardwert ist 0.
Es unterstützt die folgenden individuellen Flags:
Rindfleisch Resampling erzwingen, dieses Flag erzwingt die Verwendung von Resampling, auch wenn die Eingabe und
Ausgangsabtastraten stimmen überein.
dither_scale
Stellen Sie die Dither-Skala ein. Der Standardwert ist 1.
dither_method
Dither-Methode einstellen. Der Standardwert ist 0.
Unterstützte Werte:
rechteckig
Rechteckiges Dither auswählen
dreieckig
Dreiecks-Dither auswählen
dreieckig_hp
Wählen Sie Dreiecks-Dithering mit Hochpass
Lippenbekenntnisse
Wählen Sie Lipshitz Noise Shaping Dither
Shibata
Shibata Noise Shaping Dither auswählen
low_shibata
Wählen Sie Low Shibata Noise Shaping Dither
high_shibata
Wählen Sie hohes Shibata Noise Shaping Dither
f_gewichtet
f-gewichtetes Noise-Shaping-Dither auswählen
modifiziert_e_gewichtet
Wählen Sie modifiziertes e-gewichtetes Noise-Shaping-Dithering
verbessert_e_gewichtet
Wählen Sie verbessertes e-gewichtetes Noise-Shaping-Dithering
Resampler
Resampling-Engine einstellen. Der Standardwert ist swr.
Unterstützte Werte:
Swr Wählen Sie den nativen SW-Resampler aus; Filteroptionen Präzision und Cheby sind nicht
in diesem Fall anwendbar.
soxr
Wählen Sie den SoX-Resampler (sofern verfügbar); Kompensation und Filteroptionen
filter_size, phase_shift, filter_type & kaiser_beta, sind hier nicht anwendbar
Fall.
Filtergröße
Legen Sie nur für swr die Resampling-Filtergröße fest, der Standardwert ist 32.
Phasenverschiebung
Nur für swr, Resampling-Phasenverschiebung einstellen, Standardwert ist 10 und muss im
Intervall [0,30].
linear_interp
Lineare Interpolation verwenden, wenn auf 1 gesetzt, der Standardwert ist 0.
Cutoff-
Cutoff-Frequenz (swr: 6dB-Punkt; soxr: 0dB-Punkt) einstellen; muss ein Float-Wert sein
zwischen 0 und 1. Der Standardwert ist 0.97 bei swr und 0.91 bei soxr (was mit a
Abtastrate von 44100, behält das gesamte Audioband auf 20 kHz).
Präzision
Nur für soxr, die Genauigkeit in Bits, mit der das neu abgetastete Signal berechnet wird.
Der Standardwert von 20 (der bei geeignetem Dithering geeignet ist für a
Ziel-Bit-Tiefe von 16) gibt SoX 'Hohe Qualität'; ein Wert von 28 ergibt SoX's
'Sehr hohe Qualität'.
Cheby
Nur für Soxr, wählt Passband Rolloff keine (Chebyshev) und höhere Genauigkeit
Näherung für 'irrationale' Verhältnisse. Der Standardwert ist 0.
async
Nur für swr, einfache 1-Parameter-Audiosynchronisierung mit Zeitstempeln durch Dehnen, Zusammendrücken,
Füllen und Trimmen. Wenn Sie dies auf 1 setzen, wird das Füllen und Trimmen aktiviert, größer
Werte stellen den maximalen Betrag in Samples dar, um den die Daten gestreckt werden können oder
für jede Sekunde gedrückt. Der Standardwert ist 0, daher wird keine Kompensation angewendet
die Samples stimmen mit den Audio-Zeitstempeln überein.
erste_Punkte
Nehmen Sie nur für swr an, dass die ersten Punkte diesen Wert haben sollten. Die Zeiteinheit ist 1 / Probe
Bewertung. Dies ermöglicht das Auffüllen/Trimmen am Anfang des Streams. Standardmäßig nein
Es wird eine Annahme über die erwarteten Punkte des ersten Frames gemacht, daher ist kein Auffüllen oder Trimmen erforderlich
getan. Dies könnte zum Beispiel auf 0 gesetzt werden, um den Anfang mit Stille aufzufüllen, wenn ein
Audiostream beginnt nach dem Videostream oder um Samples mit negativen Pkten zu trimmen
wegen Geberverzögerung.
min_komp
Legen Sie nur für swr die minimale Differenz zwischen Zeitstempeln und Audiodaten fest (in
Sekunden), um das Dehnen / Zusammendrücken / Füllen oder Trimmen der Daten auszulösen, um es zu machen
mit den Zeitstempeln übereinstimmen. Die Standardeinstellung ist, dass das Dehnen/Quetschen/Füllen und Trimmen
Behinderte (min_komp = "FLT_MAX").
min_hard_comp
Legen Sie nur für swr die minimale Differenz zwischen Zeitstempeln und Audiodaten fest (in
Sekunden), um das Hinzufügen/Löschen von Samples auszulösen, damit es mit den Zeitstempeln übereinstimmt. Dies
Option ist effektiv eine Schwelle, um zwischen hart (trimmen/füllen) und weich zu wählen
(Squeeze/Stretch) Kompensation. Beachten Sie, dass alle Kompensationen standardmäßig deaktiviert sind
bis min_komp. Der Standardwert ist 0.1.
comp_duration
Legen Sie nur für swr die Dauer (in Sekunden) fest, über die die Daten gedehnt/gequetscht werden.
es stimmt mit den Zeitstempeln überein. Muss ein nicht negativer Double-Float-Wert sein, der Standardwert ist
1.0
max_soft_comp
Legen Sie nur für swr den maximalen Faktor fest, um den die Daten gedehnt/gequetscht werden, damit sie übereinstimmen
die Zeitstempel. Muss ein nicht negativer Double-Float-Wert sein, der Standardwert ist 0.
matrix_encoding
Wählen Sie Matrix-Stereokodierung.
Es akzeptiert die folgenden Werte:
keine
nichts ausgewählt
dolby
Dolby auswählen
dplii
wählen Sie Dolby Pro Logic II
Der Standardwert ist "keiner".
Filter Typ
Wählen Sie nur für swr den Resampling-Filtertyp aus. Dies betrifft nur Resampling-Operationen.
Es akzeptiert die folgenden Werte:
kubisch
kubisch auswählen
blackman_nuttall
auswählen Blackman Nuttall Windowed Sinc
Kaiser
wählen Sie Kaiser Windowed Sinc
kaiser_beta
Legen Sie nur für swr den Kaiser Window Beta-Wert fest. Muss eine ganze Zahl im Intervall [2,16] sein,
Standardwert ist 9.
Ausgabe_Beispielbits
Legen Sie nur für swr die Anzahl der verwendeten Ausgangs-Sample-Bits für das Dithering fest. Muss eine ganze Zahl sein
im Intervall [0,64] ist der Standardwert 0, was bedeutet, dass er nicht verwendet wird.
SCALER OPTIONAL
Der Videoskalierer unterstützt die folgenden benannten Optionen.
Optionen können eingestellt werden durch Angabe von -zu erhalten Wert in den FFmpeg-Tools. Für den programmatischen Gebrauch,
sie können explizit in den "SwsContext"-Optionen oder über die libavutil/opt.h API.
sws_flags
Setzen Sie die Scaler-Flags. Dies wird auch verwendet, um den Skalierungsalgorithmus einzustellen. Nur ein einziges
Algorithmus gewählt werden.
Es akzeptiert die folgenden Werte:
schnell_bilinear
Wählen Sie einen schnellen bilinearen Skalierungsalgorithmus.
bilinear
Wählen Sie den bilinearen Skalierungsalgorithmus.
bikubisch
Wählen Sie den bikubischen Skalierungsalgorithmus.
experimentell
Wählen Sie den experimentellen Skalierungsalgorithmus aus.
Nachbar
Wählen Sie den Neuskalierungsalgorithmus für den nächsten Nachbarn aus.
Gesamtfläche unserer Sitzes
Wählen Sie den Algorithmus zur Neuskalierung des Mittelwertbereichs aus.
bikubin
Wählen Sie bikubischen Skalierungsalgorithmus für die Luma-Komponente, bilinear für Chroma
Komponenten.
gauss
Wählen Sie Gaußscher Neuskalierungsalgorithmus.
aufricht
Wählen Sie den Sinc-Reskalierungsalgorithmus.
Lanczos
Wählen Sie den Lanczos-Reskalierungsalgorithmus aus.
Spline
Wählen Sie den natürlichen bikubischen Spline-Reskalierungsalgorithmus aus.
print_info
Aktivieren Sie die Druck-/Debugprotokollierung.
genaue_rnd
Aktivieren Sie die genaue Rundung.
full_chroma_int
Aktivieren Sie die vollständige Chroma-Interpolation.
full_chroma_inp
Wählen Sie den vollen Chroma-Eingang.
bitexakt
Bitgenaue Ausgabe aktivieren.
srcw
Stellen Sie die Quellbreite ein.
durchsuchen
Stellen Sie die Quellhöhe ein.
dstw
Legen Sie die Zielbreite fest.
dst
Legen Sie die Zielhöhe fest.
Quellformat
Stellen Sie das Quellpixelformat ein (muss als ganze Zahl ausgedrückt werden).
dst_format
Legen Sie das Zielpixelformat fest (muss als ganze Zahl ausgedrückt werden).
Quellbereich
Quellbereich auswählen.
dst_range
Zielbereich auswählen.
param0, param1
Legen Sie die Parameter für den Skalierungsalgorithmus fest. Die angegebenen Werte sind skalierungsspezifisch
Algorithmen und ignoriert von anderen. Die angegebenen Werte sind Gleitkommazahlen
Werte.
sws_dither
Stellen Sie den Dithering-Algorithmus ein. Akzeptiert einen der folgenden Werte. Standardwert ist
Auto.
Auto
automatische Wahl
keine
kein Zittern
bayer
bayer zittern
ed Fehlerdiffusions-Dithering
a_dither
arithmetisches Dither, basierend auf Addition
x_dither
arithmetisches Dither, basierend auf xor (mehr zufällige/weniger offensichtliche Muster als
a_dither).
Alphablend
Legen Sie die Alpha-Überblendung fest, die verwendet werden soll, wenn die Eingabe Alpha hat, die Ausgabe jedoch nicht.
Standardwert ist keine.
einheitliche_farbe
Auf eine einheitliche Hintergrundfarbe mischen
Schachbrett
Auf ein Schachbrett mischen
keine
Kein Mischen
FILTERUNG EINFÜHRUNG
Das Filtern in FFmpeg wird durch die Bibliothek libavfilter aktiviert.
In libavfilter kann ein Filter mehrere Eingänge und mehrere Ausgänge haben. Um das zu veranschaulichen
Dinge möglich sind, betrachten wir den folgenden Filtergraphen.
[Main]
Input --> Split ------------------> Overlay --> Output
| ^
|[tmp] [umdrehen]|
+-----> Zuschneiden --> Vflip -------+
Dieser Filtergraph teilt den Eingabestream in zwei Streams auf und sendet dann einen Stream durch die
Crop-Filter und den vflip-Filter, bevor Sie ihn wieder mit dem anderen Stream zusammenführen, indem Sie
darüber legen. Um dies zu erreichen, können Sie den folgenden Befehl verwenden:
ffmpeg -i INPUT -vf "split [main][tmp]; [tmp] crop=iw:ih/2:0:0, vflip [flip]; [main][flip] overlay=0:H/2" OUTPUT
Das Ergebnis ist, dass die obere Hälfte des Videos auf die untere Hälfte des Videos gespiegelt wird
Video ausgeben.
Filter in derselben linearen Kette werden durch Kommas getrennt, und unterschiedliche lineare Ketten von
Filter werden durch Semikolon getrennt. In unserem Beispiel, zuschneiden,vflip befinden sich in einer linearen Kette,
gespalten und Auflage sind getrennt in einem anderen. Die Punkte, an denen sich die linearen Ketten verbinden, sind
mit Namen in eckigen Klammern gekennzeichnet. Im Beispiel erzeugt der Splitfilter
zwei Ausgänge, die den Labels zugeordnet sind [Main] und [tmp].
Der an den zweiten Ausgang von gesendete Stream gespalten, beschriftet als [tmp], wird verarbeitet durch die
Ernte Filter, der die untere Hälfte des Videos wegschneidet und dann vertikal
umgedreht. Die Auflage filter nimmt in input die erste unveränderte Ausgabe des Splitfilters
(die als gekennzeichnet wurde [Main]) und überlagern seine untere Hälfte mit der Ausgabe, die von der
zuschneiden,vflip Filterkette.
Einige Filter nehmen als Eingabe eine Liste von Parametern auf: Sie werden nach dem Filternamen angegeben
und ein Gleichheitszeichen und werden durch einen Doppelpunkt voneinander getrennt.
Es gibt sogenannte Quelle Filter die keinen Audio-/Videoeingang haben, und Waschbecken
Filter die keinen Audio/Video-Ausgang haben.
GRAPH
Die graph2dot Programm im FFmpeg . enthalten Werkzeuge Verzeichnis kann verwendet werden, um a . zu analysieren
Filtergraph Beschreibung und geben Sie eine entsprechende Textdarstellung im Punkt aus
Sprache.
Rufen Sie den Befehl auf:
graph2dot -h
um zu sehen, wie man es benutzt graph2dot.
Sie können die Punktbeschreibung dann an die Punkt Programm (aus der graphviz-Suite von
Programme) und erhalten eine grafische Darstellung des Filtergraphen.
Zum Beispiel die Befehlsfolge:
Echo | \
tools/graph2dot -o graph.tmp && \
Punkt -Tpng graph.tmp -o graph.png && \
grafik anzeigen.png
kann verwendet werden, um ein Bild zu erstellen und anzuzeigen, das den von der
GRAPH_DESCRIPTION Schnur. Beachten Sie, dass diese Zeichenfolge ein vollständiger in sich abgeschlossener Graph sein muss.
mit seinen Ein- und Ausgängen explizit definiert. Zum Beispiel, wenn Ihre Befehlszeile von . ist
die Form:
ffmpeg -i Infile -vf Scale=640:360 Outfile
deine GRAPH_DESCRIPTION String muss die Form haben:
nullsrc,scale=640:360,nullsenke
Möglicherweise müssen Sie auch die nullsrc Parameter und fügen Sie a . hinzu Format filtern, um
eine bestimmte Eingabedatei simulieren.
FILTERGRAFIK BESCHREIBUNG
Ein Filtergraph ist ein gerichteter Graph verbundener Filter. Es kann Zyklen enthalten, und da
können mehrere Verknüpfungen zwischen einem Filterpaar sein. Jeder Link hat ein Eingabepad auf einer Seite
Verbinden Sie es mit einem Filter, von dem es seinen Eingang nimmt, und einem Ausgangs-Pad auf dem anderen
Seite, die es mit einem Filter verbindet, der seinen Ausgang akzeptiert.
Jeder Filter in einem Filtergraph ist eine Instanz einer Filterklasse, die im
Anwendung, die die Funktionen und die Anzahl der Eingangs- und Ausgangspads des
Filter.
Ein Filter ohne Eingangspads wird als "Quelle" bezeichnet und ein Filter ohne Ausgangspads ist
als "Senke" bezeichnet.
Filtergrafik Syntax
Ein Filtergraph hat eine textuelle Darstellung, die von der . erkannt wird -Filter/-vf/-N und
-filter_komplex Optionen in ffmpeg und -vf/-N in ffplayUnd durch die
"avfilter_graph_parse_ptr()" Funktion definiert in libavfilter/avfilter.h.
Eine Filterkette besteht aus einer Folge verbundener Filter, von denen jeder mit dem
vorherige in der folge. Eine Filterkette wird durch eine Liste von ","-getrennten
Beschreibungen filtern.
Ein Filtergraph besteht aus einer Folge von Filterketten. Eine Folge von Filterketten ist
dargestellt durch eine Liste von ";"-getrennten Filterkettenbeschreibungen.
Ein Filter wird durch eine Zeichenfolge der Form dargestellt:
[in_link_1]...[in_link_N]Filtername=Argumente[out_link_1]...[out_link_M]
Filtername ist der Name der Filterklasse, von der der beschriebene Filter eine Instanz ist
of, und muss der Name einer der im Programm registrierten Filterklassen sein. Die
dem Namen der Filterklasse folgt optional ein String "=Argumente".
Argumente ist ein String, der die Parameter enthält, die zum Initialisieren des Filters verwendet werden
Beispiel. Es kann eine von zwei Formen haben:
· Eine ':'-getrennte Liste von Schlüssel=Wert Paaren.
· Eine ':'-getrennte Liste von Wert. In diesem Fall wird davon ausgegangen, dass die Schlüssel die Option sind
Namen in der Reihenfolge, in der sie deklariert werden. ZB der Filter "fade" deklariert drei Optionen in
diese Bestellung -- tippe, start_frame und nb_frames. Dann die Parameterliste in:0:30 Mittel
dass der Wert in ist der Option zugeordnet tippe, 0 zu start_frame und 30 zu
nb_frames.
· Eine ':'-getrennte Liste von gemischten Direkten Wert und lang Schlüssel=Wert Paare. Die direkte Wert
muss dem vorangehen Schlüssel=Wert Paare, und folgen der gleichen Nebenbedingungsreihenfolge der
vorheriger Punkt. Folgende Schlüssel=Wert Paare können in beliebiger Reihenfolge eingestellt werden.
Wenn der Optionswert selbst eine Liste von Elementen ist (z. B. nimmt der Filter "Format" eine Liste von
Pixelformate), werden die Elemente in der Liste normalerweise durch getrennt |.
Die Liste der Argumente kann mit dem Zeichen zitiert werden ' als Anfangs- und Endzeichen, und
der Charakter \ um die Zeichen innerhalb des zitierten Textes zu maskieren; ansonsten das argument
string gilt als beendet, wenn das nächste Sonderzeichen (zur Menge gehörend)
[]=;,) begegnet.
Dem Namen und den Argumenten des Filters wird optional eine Liste von vorangestellt und gefolgt
Link-Etiketten. Ein Link-Label ermöglicht es, einen Link zu benennen und ihn einer Filterausgabe zuzuordnen
oder Eingabepad. Die vorhergehenden Etiketten in_link_1 ... in_link_N, sind dem Filter zugeordnet
Eingabepads, die folgenden Beschriftungen out_link_1 ... out_link_M, sind dem Ausgang zugeordnet
Pads.
Wenn im Filtergraph zwei Linklabels mit demselben Namen gefunden werden, wird ein Link zwischen den
entsprechende Eingabe- und Ausgabe-Pad erstellt.
Wenn ein Ausgangs-Pad nicht beschriftet ist, wird es standardmäßig mit dem ersten unbeschrifteten Eingang verknüpft
Pad des nächsten Filters in der Filterkette. Zum Beispiel in der Filterkette
nullsrc, split[L1], [L2]overlay, nullsink
die Split-Filter-Instanz hat zwei Ausgangs-Pads und die Overlay-Filter-Instanz zwei Eingänge
Pads. Das erste Output-Pad von Split ist mit "L1" gekennzeichnet, das erste Input-Pad von Overlay ist
mit "L2" beschriftet, und das zweite Ausgangs-Pad von Split ist mit dem zweiten Eingangs-Pad von verbunden
Overlay, die beide unbeschriftet sind.
Wenn in einer Filterbeschreibung das Eingabelabel des ersten Filters nicht angegeben ist, ist "in"
vermutet; wenn das Ausgabelabel des letzten Filters nicht angegeben ist, wird "out" angenommen.
In einer vollständigen Filterkette müssen alle unbeschrifteten Eingangs- und Ausgangspads des Filters
in Verbindung gebracht. Ein Filtergraph gilt als gültig, wenn alle Filtereingangs- und -ausgangspads von
alle Filterketten sind verbunden.
Libavfilter wird automatisch eingefügt Treppe Filter, bei denen eine Formatkonvertierung erforderlich ist.
Es ist möglich, swscale-Flags für diese automatisch eingefügten Scaler zu spezifizieren von
"sws_flags= ." voranstellenFlaggen;" zur Beschreibung des Filtergraphen.
Hier ist eine BNF-Beschreibung der Filtergraph-Syntax:
::= Folge von alphanumerischen Zeichen und '_'
::= "[" "]"
::= [ ]
::= Zeichenfolge (evtl. zitiert)
::= [ ] ["=" ] [ ]
::= [, ]
::= [sws_flags= ;] [; ]
Notizen on Filtergrafik Flucht
Die Zusammensetzung der Filtergraph-Beschreibung umfasst mehrere Escape-Ebenen. Sehen "Zitieren
und Flucht" Abschnitt in ffmpeg-utils(1) manuell Weitere Informationen über die
Fluchtverfahren eingesetzt.
Ein Escape der ersten Ebene wirkt sich auf den Inhalt jedes Filteroptionswerts aus, der Folgendes enthalten kann:
das Sonderzeichen ":" zum Trennen von Werten oder eines der Escape-Zeichen "\'".
Eine zweite Ebene Escaping betrifft die gesamte Filterbeschreibung, die die
Escape-Zeichen "\'" oder die Sonderzeichen "[],;" vom Filtergraph verwendet
Beschreibung.
Wenn Sie schließlich einen Filtergraph auf einer Shell-Befehlszeile angeben, müssen Sie Folgendes ausführen:
Escape der dritten Ebene für die darin enthaltenen Shell-Sonderzeichen.
Betrachten Sie beispielsweise die folgende Zeichenfolge als eingebettet in die Zeichentext Filter
Beschreibung Text Wert:
dies ist eine 'Zeichenfolge': kann ein oder mehrere Sonderzeichen enthalten
Diese Zeichenfolge enthält das Escape-Sonderzeichen "'" und das Sonderzeichen ":", also
es muss auf diese Weise entkommen werden:
text=dies ist ein \'string\'\: kann ein oder mehrere Sonderzeichen enthalten
Beim Einbetten der Filterbeschreibung in a . ist eine zweite Escape-Ebene erforderlich
filtergraph description, um alle Sonderzeichen des Filtergraphen zu maskieren. Daher
das obige Beispiel wird:
drawtext=text=dies ist ein \\\'string\\\'\\: kann ein\ oder mehrere\ Sonderzeichen enthalten
(beachten Sie, dass zusätzlich zu den "\'"-Escape-Sonderzeichen auch "," angegeben werden muss
entkam).
Schließlich wird beim Schreiben der Filtergraph-Beschreibung eine zusätzliche Escape-Ebene benötigt
in einem Shell-Befehl, der von den Escape-Regeln der übernommenen Shell abhängt. Zum Beispiel,
unter der Annahme, dass "\" etwas Besonderes ist und mit einem anderen "\" maskiert werden muss, die vorherige Zeichenfolge
ergibt sich schließlich:
-vf "drawtext=text=dies ist ein \\\\\\'string\\\\\\'\\\\: kann ein oder mehrere\\ Sonderzeichen enthalten"
ZEITPLAN BEARBEITEN
Einige Filter unterstützen eine generische ermöglichen Möglichkeit. Für die Filter, die die Zeitachsenbearbeitung unterstützen,
Diese Option kann auf einen Ausdruck gesetzt werden, der ausgewertet wird, bevor ein Frame an den . gesendet wird
Filter. Bei einer Bewertung ungleich Null wird der Filter aktiviert, andernfalls wird der Rahmen
wird unverändert an den nächsten Filter im Filtergraph gesendet.
Der Ausdruck akzeptiert die folgenden Werte:
t Zeitstempel in Sekunden ausgedrückt, NAN, wenn der Eingabezeitstempel unbekannt ist
n fortlaufende Nummer des Eingaberahmens, beginnend bei 0
Post die Position in der Datei des Eingabeframes, NAN falls unbekannt
w
h Breite und Höhe des Eingabeframes bei Video
Darüber hinaus unterstützen diese Filter eine ermöglichen Befehl, der verwendet werden kann, um die
Ausdruck.
Wie jede andere Filteroption ist die ermöglichen Option folgt den gleichen Regeln.
Um beispielsweise einen Unschärfefilter zu aktivieren (intelligente Unschärfe) von 10 Sekunden bis 3 Minuten und a
Kurven Filter ab 3 Sekunden:
smartblur = enable='zwischen(t,10,3*60)',
Kurven = enable='gte(t,3)' : Preset=cross_process
AUDIO FILTER
Wenn Sie Ihren FFmpeg-Build konfigurieren, können Sie jeden der vorhandenen Filter mit . deaktivieren
"--filter deaktivieren". Die Konfigurationsausgabe zeigt die Audiofilter an, die in Ihrem
bauen.
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Audiofilter.
überblenden
Wenden Sie Crossfade von einem Eingangsaudiostream auf einen anderen Eingangsaudiostream an. Das Kreuz
Fade wird für die angegebene Dauer gegen Ende des ersten Streams angewendet.
Der Filter akzeptiert die folgenden Optionen:
nb_proben, ns
Geben Sie die Anzahl der Samples an, für die der Crossfade-Effekt andauern soll. Am Ende
des Crossfade-Effekts ist das erste Eingangsaudio völlig stumm. Standard ist
44100
Dauer, d
Geben Sie die Dauer des Crossfade-Effekts an. Sehen Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell für die akzeptierte Syntax. Standardmäßig ist die Dauer festgelegt
by nb_proben. Wenn gesetzt, wird diese Option anstelle von verwendet nb_proben.
Überlappung, o
Sollte das Ende des ersten Streams mit dem Start des zweiten Streams überlappen. Standard ist aktiviert.
Kurve1
Legen Sie die Kurve für den Crossfade-Übergang für den ersten Stream fest.
Kurve2
Legen Sie die Kurve für den Crossfade-Übergang für den zweiten Stream fest.
Beschreibung der verfügbaren Kurventypen siehe verblassen Beschreibung des Filters.
Beispiele
· Crossfade von einem Eingang zum anderen:
ffmpeg -i erste.flac -i zweite.flac -filter_complex acrossfade=d=10:c1=exp:c2=exp Ausgabe.flac
· Crossfade von einem Eingang zum anderen, aber ohne Überlappung:
ffmpeg -i first.flac -i second.flac -filter_complex acrossfade=d=10:o=0:c1=exp:c2=exp output.flac
eine Verzögerung
Einen oder mehrere Audiokanäle verzögern.
Samples im verzögerten Kanal sind mit Stille gefüllt.
Der Filter akzeptiert die folgende Option:
Verzögerungen
Legen Sie eine Liste der Verzögerungen in Millisekunden für jeden Kanal fest, getrennt durch '|'. Mindestens ein
Verzögerung größer als 0 sollte bereitgestellt werden. Ungenutzte Verzögerungen werden stillschweigend ignoriert. Wenn
Anzahl der gegebenen Verzögerungen ist kleiner als die Anzahl der Kanäle alle verbleibenden Kanäle werden
nicht verzögert werden.
Beispiele
· Verzögern Sie den ersten Kanal um 1.5 Sekunden, den dritten Kanal um 0.5 Sekunden und lassen Sie den
zweiten Kanal (und alle anderen Kanäle, die vorhanden sein können) unverändert.
Verzögerung=1500|0|500
Echo
Wenden Sie Echos auf das Eingangsaudio an.
Echos sind reflektierter Schall und können natürlich zwischen Bergen auftreten (und manchmal groß)
Gebäude) beim Sprechen oder Rufen; digitale Echoeffekte emulieren dieses Verhalten und sind
wird oft verwendet, um den Klang eines einzelnen Instruments oder Gesangs auszufüllen. Der Zeitunterschied
zwischen dem Originalsignal und der Reflexion ist die "Verzögerung", und die Lautstärke des
reflektiertes Signal ist der "Zerfall". Mehrere Echos können unterschiedliche Verzögerungen und Abklingzeiten aufweisen.
Eine Beschreibung der akzeptierten Parameter folgt.
in_gain
Stellen Sie die Eingangsverstärkung des reflektierten Signals ein. Der Standardwert ist 0.6.
out_gain
Stellen Sie die Ausgangsverstärkung des reflektierten Signals ein. Der Standardwert ist 0.3.
Verzögerungen
Liste der Zeitintervalle in Millisekunden zwischen Originalsignal und Reflexionen einstellen
getrennt durch '|'. Der zulässige Bereich für jede "Verzögerung" ist "(0 - 90000.0]). Der Standardwert ist 1000.
verfällt
Stellen Sie die Liste der Lautstärken der reflektierten Signale ein, die durch '|' getrennt sind. Zulässiger Bereich für jeden
"Zerfall" ist "(0 - 1.0)". Der Standardwert ist 0.5.
Beispiele
· Lassen Sie es so klingen, als ob es doppelt so viele Instrumente gibt, wie tatsächlich gespielt werden:
Echo=0.8:0.88:60:0.4
· Wenn die Verzögerung sehr kurz ist, klingt es wie ein (metallischer) Roboter, der Musik spielt:
Echo=0.8:0.88:6:0.4
· Eine längere Verzögerung klingt wie ein Open-Air-Konzert in den Bergen:
Echo=0.8:0.9:1000:0.3
· Wie oben, jedoch mit einem weiteren Berg:
aecho=0.8:0.9:1000|1800:0.3|0.25
eval
Ändern Sie ein Audiosignal gemäß den angegebenen Ausdrücken.
Dieser Filter akzeptiert einen oder mehrere Ausdrücke (einen für jeden Kanal), die ausgewertet werden
und verwendet, um ein entsprechendes Audiosignal zu modifizieren.
Es akzeptiert die folgenden Parameter:
ausdrücken
Legen Sie die durch '|' getrennte Liste der Ausdrücke für jeden einzelnen Kanal fest. Wenn die Anzahl der
Eingangskanäle ist größer als die Anzahl der Ausdrücke, die zuletzt angegebene
Ausdruck wird für die verbleibenden Ausgangskanäle verwendet.
Kanal_Layout, c
Legen Sie das Layout des Ausgangskanals fest. Wenn nicht angegeben, wird das Kanallayout durch die
Anzahl von Ausdrücken. Wenn auf eingestellt gleich, wird standardmäßig der gleiche Eingangskanal verwendet
Layout.
Jeder Ausdruck in ausdrücken kann die folgenden Konstanten und Funktionen enthalten:
ch Kanalnummer des aktuellen Ausdrucks
n Nummer der ausgewerteten Probe, beginnend bei 0
s Beispielrate
t Zeit der ausgewerteten Probe in Sekunden
nb_in_channels
nb_out_channels
Ein- und Ausgangsanzahl der Kanäle
Wert(CH)
der Wert des Eingangskanals mit Nummer CH
Hinweis: Dieser Filter ist langsam. Für eine schnellere Verarbeitung sollten Sie einen dedizierten Filter verwenden.
Beispiele
· Halbe Lautstärke:
aeval=val(ch)/2:c=gleich
· Phase des zweiten Kanals invertieren:
aeval=Welle(0)|-Welle(1)
verblassen
Wenden Sie den Ein-/Ausblendeffekt auf das Eingangsaudio an.
Eine Beschreibung der akzeptierten Parameter folgt.
Art, t
Geben Sie den Effekttyp an, kann entweder "in" für ein Fade-In oder "out" für ein Fade-Out sein
Wirkung. Standard ist "in".
start_sample, ss
Geben Sie die Nummer des Start-Samples für den Beginn der Anwendung des Fade-Effekts an. Standard
ist 0.
nb_proben, ns
Geben Sie die Anzahl der Samples an, für die der Fade-Effekt andauern soll. Am Ende von
Einblendeffekt hat das Ausgangsaudio die gleiche Lautstärke wie das Eingangsaudio, bei der
Am Ende des Fade-Out-Übergangs ist die Audioausgabe stumm. Der Standardwert ist 44100.
Startzeit, st
Geben Sie die Startzeit des Fade-Effekts an. Standard ist 0. Der Wert muss angegeben werden
als Zeitdauer; sehen Uhrzeit Dauer Abschnitt in ffmpeg-utils(1) manuell für
die akzeptierte Syntax. Wenn gesetzt, wird diese Option anstelle von verwendet start_sample.
Dauer, d
Geben Sie die Dauer des Fade-Effekts an. Sehen Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell für die akzeptierte Syntax. Am Ende des Einblendeffekts wird der
Ausgangsaudio hat die gleiche Lautstärke wie das Eingangsaudio am Ende der Ausblendung
Übergang wird die Audioausgabe stumm sein. Standardmäßig wird die Dauer bestimmt durch
nb_proben. Wenn gesetzt, wird diese Option anstelle von verwendet nb_proben.
Kurve
Kurve für Fade-Übergang einstellen.
Es akzeptiert die folgenden Werte:
drei Wählen Sie dreieckige, lineare Steigung (Standard)
qsin
Wählen Sie ein Viertel der Sinuswelle
hsin
Wählen Sie die Hälfte der Sinuswelle
Inspiration
Wählen Sie die exponentielle Sinuswelle
Log logarithmisch auswählen
ipar
invertierte Parabel auswählen
hier Quadratisch auswählen
Würfel kubisch auswählen
squ Quadratwurzel wählen
cbr Kubikwurzel auswählen
von Parabel auswählen
exp wählen Sie exponentiell
iqsin
Wählen Sie invertiertes Viertel der Sinuswelle
ihsin
Wählen Sie die invertierte Hälfte der Sinuswelle
dess
Wählen Sie einen doppelt exponentiellen Sitz
desi
wähle doppelexponentielles Sigmoid
Beispiele
· Einblenden der ersten 15 Sekunden des Audios:
afade=t=in:ss=0:d=15
· Blenden Sie die letzten 25 Sekunden eines 900-Sekunden-Audios aus:
afade=t=aus:st=875:d=25
aformat
Legen Sie Einschränkungen des Ausgabeformats für das Eingabeaudio fest. Der Rahmen wird am meisten verhandeln
geeignetes Format, um Konvertierungen zu minimieren.
Es akzeptiert die folgenden Parameter:
sample_fmts
Eine durch '|' getrennte Liste der angeforderten Beispielformate.
Sampleraten
Eine durch '|' getrennte Liste der angeforderten Abtastraten.
Kanallayouts
Eine durch '|' getrennte Liste von angeforderten Kanallayouts.
Weitere Informationen finden Sie auch in den Kanal Layout Abschnitt in ffmpeg-utils(1) manuell für die erforderliche Syntax.
Wird ein Parameter weggelassen, sind alle Werte zulässig.
Erzwingen Sie die Ausgabe entweder auf 8-Bit- ohne Vorzeichen oder auf 16-Bit-Stereo mit Vorzeichen
aformat=sample_fmts=u8|s16:channel_layouts=stereo
Allpass
Anwenden eines zweipoligen Allpassfilters mit Mittenfrequenz (in Hz) Frequenz, und Filter-
Breite Breite. Ein Allpassfilter ändert die Frequenz des Audios in die Phasenbeziehung
ohne seine Frequenz-zu-Amplituden-Beziehung zu ändern.
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Frequenz in Hz einstellen.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Geben Sie die Bandbreite eines Filters in width_type-Einheiten an.
eine Zusammenführung
Kombinieren Sie zwei oder mehr Audiostreams zu einem einzigen Mehrkanalstream.
Der Filter akzeptiert die folgenden Optionen:
Eingänge
Stellen Sie die Anzahl der Eingänge ein. Standard ist 2.
Wenn die Kanallayouts der Eingänge unzusammenhängend und damit kompatibel sind, wird der Kanal
Layout der Ausgabe wird entsprechend eingestellt und die Kanäle werden neu geordnet als
notwendig. Wenn die Kanallayouts der Eingänge nicht disjunkt sind, hat der Ausgang alle
die Kanäle des ersten Eingangs, dann alle Kanäle des zweiten Eingangs, in dieser Reihenfolge,
und das Kanallayout des Ausgangs ist der Standardwert, der dem Gesamtwert entspricht
Anzahl der Kanäle.
Wenn beispielsweise der erste Eingang in 2.1 (FL+FR+LF) und der zweite Eingang FC+BL+BR ist,
dann erfolgt die Ausgabe in 5.1, mit den Kanälen in der folgenden Reihenfolge: a1, a2, b1, a3,
b2, b3 (a1 ist der erste Kanal des ersten Eingangs, b1 ist der erste Kanal des zweiten
Eingang).
Wenn hingegen beide Eingänge in Stereo sind, sind die Ausgangskanäle in der Standardeinstellung
Reihenfolge: a1, a2, b1, b2, und das Kanallayout wird willkürlich auf 4.0 gesetzt, was oder
möglicherweise nicht der erwartete Wert.
Alle Eingänge müssen die gleiche Abtastrate und das gleiche Format haben.
Wenn die Eingaben nicht die gleiche Dauer haben, stoppt die Ausgabe mit der kürzesten.
Beispiele
· Zwei Mono-Dateien zu einem Stereo-Stream zusammenführen:
amovie=left.wav [l] ; amovie=rechts.mp3 [r] ; [l] [r] verschmelzen
· Mehrere Zusammenführungen unter der Annahme von 1 Videostream und 6 Audiostreams in input.mkv:
ffmpeg -i input.mkv -filter_complex "[0:1][0:2][0:3][0:4][0:5][0:6] amerge=inputs=6" -c:a pcm_s16le Ausgabe.mkv
eine Mischung
Mischt mehrere Audioeingänge zu einem einzigen Ausgang.
Beachten Sie, dass dieser Filter nur Float-Samples unterstützt (die eine Zusammenführung und Pfanne Audiofilter
viele Formate unterstützen). Wenn die eine Mischung Eingang hat dann ganzzahlige Samples eine Probe wird sein
automatisch eingefügt, um die Umwandlung in Float-Samples durchzuführen.
Zum Beispiel
ffmpeg -i INPUT1 -i INPUT2 -i INPUT3 -filter_complex amix=inputs=3:duration=first:dropout_transition=3 AUSGANG
mischt 3 Eingangs-Audiostreams zu einem einzigen Ausgang mit der gleichen Dauer wie der erste
Eingang und einer Dropout-Übergangszeit von 3 Sekunden.
Es akzeptiert die folgenden Parameter:
Eingänge
Die Anzahl der Eingänge. Wenn nicht angegeben, wird standardmäßig 2 verwendet.
Dauer
So bestimmen Sie das Ende des Streams.
am längsten
Die Dauer der längsten Eingabe. (Ursprünglich)
kürzeste
Die Dauer der kürzesten Eingabe.
zuerst
Die Dauer der ersten Eingabe.
dropout_transition
Die Übergangszeit in Sekunden für die Volumenrenormierung, wenn ein Eingabestream endet.
Der Standardwert beträgt 2 Sekunden.
annull
Übergeben Sie die Audioquelle unverändert an den Ausgang.
ein Polster
Füllen Sie das Ende eines Audiostreams mit Stille.
Dies kann zusammen mit verwendet werden ffmpeg -kürzeste um Audiostreams auf die gleiche Länge zu verlängern
als Videostream.
Eine Beschreibung der akzeptierten Optionen folgt.
Paketgröße
Legen Sie die Paketgröße für die Stille fest. Der Standardwert ist 4096.
pad_len
Legen Sie die Anzahl der Stille-Samples fest, die am Ende hinzugefügt werden sollen. Nachdem der Wert erreicht ist,
der Stream wird beendet. Diese Option schließt sich gegenseitig aus mit ganz_len.
ganz_len
Legen Sie die minimale Gesamtanzahl von Samples im Ausgabeaudiostream fest. Wenn der Wert ist
länger als die Eingangsaudiolänge, wird am Ende Stille hinzugefügt, bis der Wert . ist
erreicht. Diese Option schließt sich gegenseitig aus mit pad_len.
Wenn weder die pad_len noch das ganz_len Option gesetzt ist, fügt der Filter Stille hinzu
Ende des Eingabestroms auf unbestimmte Zeit.
Beispiele
· Fügen Sie 1024 Stille-Samples am Ende der Eingabe hinzu:
apad=pad_len=1024
· Stellen Sie sicher, dass die Audioausgabe mindestens 10000 Samples enthält, füllen Sie die Eingabe mit
Stille bei Bedarf:
apad=whole_len=10000
· Verwenden ffmpeg um den Audioeingang mit Stille aufzufüllen, damit der Videostream immer
Ergebnis am kürzesten und wird bei Verwendung bis zum Ende in die Ausgabedatei konvertiert
kürzeste Option:
ffmpeg -i VIDEO -i AUDIO -filter_complex "[1:0]apad" -kürzeste AUSGABE
Aphaser
Fügen Sie dem Eingangsaudio einen Phaseneffekt hinzu.
Ein Phaser-Filter erzeugt eine Reihe von Spitzen und Tälern im Frequenzspektrum. Die
Die Position der Spitzen und Täler werden so moduliert, dass sie sich im Laufe der Zeit ändern, wodurch ein
schwungvolle Wirkung.
Eine Beschreibung der akzeptierten Parameter folgt.
in_gain
Eingangsverstärkung einstellen. Der Standardwert ist 0.4.
out_gain
Ausgangsverstärkung einstellen. Standard ist 0.74
verzögern
Verzögerung in Millisekunden einstellen. Der Standardwert ist 3.0.
Verfall
Verfall einstellen. Der Standardwert ist 0.4.
Geschwindigkeit
Modulationsgeschwindigkeit in Hz einstellen. Der Standardwert ist 0.5.
tippe
Modulationsart einstellen. Standard ist dreieckig.
Es akzeptiert die folgenden Werte:
dreieckig, t
sinusförmig, s
eine Probe
Resample das Eingangsaudio mit den angegebenen Parametern mithilfe der Bibliothek libswresample. Wenn
keine angegeben sind, konvertiert der Filter automatisch zwischen seiner Eingabe und
Ausgabe.
Dieser Filter ist auch in der Lage, die Audiodaten zu dehnen/zusammenzudrücken, damit sie den Zeitstempeln entsprechen
oder um Stille einzufügen / Audio auszuschneiden, damit es mit den Zeitstempeln übereinstimmt, machen Sie eine Kombination von
beides oder keines von beiden.
Der Filter akzeptiert die Syntax [Beispielrate:]resampler_optionen, Wobei Beispielrate drückt aus
eine Abtastrate und resampler_optionen ist eine Liste von Haupt=Wert Paare, getrennt durch ":". Sehen
die vollständige Liste der unterstützten Optionen finden Sie im Handbuch zu ffmpeg-resampler.
Beispiele
· Resample das Eingangsaudio auf 44100 Hz:
aresample=44100
· Dehnen/Squeezen von Samples auf die angegebenen Zeitstempel, mit maximal 1000 Samples pro
zweite Entschädigung:
aresample=async=1000
asetsamples
Legen Sie die Anzahl der Samples pro Ausgabe-Audioframe fest.
Das letzte Ausgabepaket kann eine andere Anzahl von Samples enthalten, da der Filter spült
alle verbleibenden Samples, wenn das Eingangsaudiosignal zu Ende ist.
Der Filter akzeptiert die folgenden Optionen:
nb_out_samples, n
Legen Sie die Anzahl der Frames pro Ausgabe-Audioframe fest. Die Nummer ist als
Anzahl von Beispielen für jeder Kanal. Der Standardwert ist 1024.
Pad, p
Wenn der Wert auf 1 gesetzt ist, füllt der Filter den letzten Audioframe mit Nullen auf, sodass der letzte
Frame enthält die gleiche Anzahl von Samples wie die vorherigen. Standardwert ist
1.
Um beispielsweise die Anzahl der Samples pro Frame auf 1234 zu setzen und das Padding für die zu deaktivieren
letzter Frame, verwenden Sie:
asetsamples=n=1234:p=0
getrennt
Stellen Sie die Abtastrate ein, ohne die PCM-Daten zu ändern. Dies führt zu einer Geschwindigkeitsänderung
und Pitch.
Der Filter akzeptiert die folgenden Optionen:
Beispielrate, r
Stellen Sie die Ausgabe-Sample-Rate ein. Der Standardwert ist 44100 Hz.
ashowinfo
Zeigen Sie eine Zeile mit verschiedenen Informationen für jeden eingegebenen Audio-Frame an. Das Eingangsaudio ist
Nicht modifiziert.
Die angezeigte Zeile enthält eine Folge von Schlüssel/Wert-Paaren der Form Haupt:Wert.
In der Ausgabe werden folgende Werte angezeigt:
n Die (laufende) Nummer des Eingabeframes, beginnend bei 0.
pts Der Präsentationszeitstempel des Eingabeframes in Zeitbasiseinheiten; die Zeitbasis
hängt vom Filtereingangspad ab und beträgt normalerweise 1/Beispielrate.
pts_time
Der Präsentationszeitstempel des Eingabeframes in Sekunden.
Post Position des Frames im Eingabestream, -1 wenn diese Information nicht verfügbar ist
und/oder bedeutungslos (zum Beispiel bei synthetischem Audio)
fmt Das Beispielformat.
Chlayout
Das Kanallayout.
Rate
Die Abtastrate für den Audio-Frame.
nb_proben
Die Anzahl der Samples (pro Kanal) im Frame.
Prüfsumme
Die Adler-32-Prüfsumme (in hexadezimal gedruckt) der Audiodaten. Für planares Audio,
die Daten werden so behandelt, als ob alle Ebenen verkettet wären.
plane_checksums
Eine Liste von Adler-32-Prüfsummen für jede Datenebene.
Statistiken
Zeigen Sie statistische Informationen im Zeitbereich zu den Audiokanälen an. Statistiken sind
für jeden Audiokanal berechnet und angezeigt und ggf. eine Gesamtzahl
ist auch gegeben.
Es akzeptiert die folgende Option:
Länge
Kurze Fensterlänge in Sekunden, verwendet für Spitzen- und Tiefstwert-RMS-Messungen. Standard ist
0.05 (50 Millisekunden). Zulässiger Bereich ist "[0.1 - 10]".
Metadaten
Legen Sie die Metadateninjektion fest. Alle Metadatenschlüssel haben das Präfix "lavfi.astats.X",
wobei "X" die Kanalnummer beginnend mit 1 oder die Zeichenfolge "Overall" ist. Standard ist deaktiviert.
Verfügbare Schlüssel für jeden Kanal sind: DC_offset Min_level Max_level Min_difference
Max_difference Mean_difference Peak_level RMS_peak RMS_Trog Crest_factor Flat_factor
Peak_count Bit_Tiefe
und für Gesamt: DC_offset Min_level Max_level Min_difference Max_difference
Mittelwertdifferenz Peak_level RMS_level RMS_peak RMS_Trog Flat_factor Peak_count
Bit_Tiefe Anzahl_der_Beispiele
Zum Beispiel sieht der vollständige Schlüssel so aus "lavfi.astats.1.DC_offset" oder so
"lavfi.astats.Overall.Peak_count".
Für eine Beschreibung, was jede Taste bedeutet, lesen Sie unten.
zurückstellen
Legen Sie die Anzahl der Frames fest, nach denen die Statistiken neu berechnet werden. Standard ist
behindert.
Es folgt eine Beschreibung jedes angezeigten Parameters:
DC Offset
Mittlere Amplitudenverschiebung von Null.
Min. Grad des
Minimaler Probenpegel.
Max Grad des
Maximale Probenmenge.
Min. Unterschied
Minimaler Unterschied zwischen zwei aufeinanderfolgenden Proben.
Max Unterschied
Maximaler Unterschied zwischen zwei aufeinanderfolgenden Proben.
Bedeuten Unterschied
Mittlere Differenz zwischen zwei aufeinanderfolgenden Stichproben. Der Durchschnitt jeder Differenz
zwischen zwei aufeinanderfolgenden Proben.
Haupt Grad des dB
RMS Grad des dB
Standard-Peak- und RMS-Pegel gemessen in dBFS.
RMS Haupt dB
RMS Trog dB
Spitzen- und Tiefstwerte für RMS-Pegel, gemessen über ein kurzes Fenster.
Hals Faktor
Standardverhältnis von Spitzen- zu RMS-Pegel (Hinweis: nicht in dB).
Flache Schaltflächen Faktor
Flachheit (dh aufeinanderfolgende Abtastungen mit dem gleichen Wert) des Signals an seiner Spitze
Ebenen (dh entweder Min. Grad des or Max Grad des ).
Haupt zählen
Anzahl der Gelegenheiten (nicht die Anzahl der Abtastungen), die das Signal entweder erreicht hat Min.
Grad des or Max Grad des .
Bit Tiefe
Gesamtbittiefe des Audios. Anzahl der Bits, die für jeden Abtastwert verwendet werden.
astreamsync
Leiten Sie zwei Audiostreams weiter und steuern Sie die Reihenfolge, in der die Puffer weitergeleitet werden.
Der Filter akzeptiert die folgenden Optionen:
Ausdruck, e
Legen Sie den Ausdruck fest, der entscheidet, welcher Stream als nächstes weitergeleitet werden soll: wenn das Ergebnis . ist
negativ, der erste Stream wird weitergeleitet; wenn das Ergebnis positiv oder null ist, die Sekunde
Stream weitergeleitet wird. Es kann die folgenden Variablen verwenden:
b1 b2
Anzahl der Puffer, die bisher in jedem Stream weitergeleitet wurden
s1 s2
Anzahl der Samples, die bisher in jedem Stream weitergeleitet wurden
t1 t2
aktueller Zeitstempel jedes Streams
Der Standardwert ist "t1-t2", was bedeutet, dass immer der Stream weitergeleitet wird, der a . hat
kleinerer Zeitstempel.
Beispiele
Stresstest "amerge" durch zufälliges Senden von Puffern an den falschen Eingang, während gleichzeitig vermieden wird
eine ziemliche Desynchronisation:
amovie=datei.ogg [a] ; amovie=Datei.mp3 [b] ;
[a] [b] astreamsync=(2*zufällig(1))-1+tanh(5*(t1-t2)) [a2] [b2] ;
[a2] [b2] fusionieren
asynct
Synchronisieren Sie Audiodaten mit Zeitstempeln, indem Sie sie zusammendrücken/dehnen und/oder fallen lassen
Samples/Hinzufügen von Stille, wenn nötig.
Dieser Filter ist nicht standardmäßig erstellt, bitte verwenden Sie eine Probe quetschen/dehnen.
Es akzeptiert die folgenden Parameter:
kompensieren
Aktivieren Sie das Dehnen/Squeezen der Daten, damit sie mit den Zeitstempeln übereinstimmen. Deaktiviert von
Ursprünglich. Wenn deaktiviert, werden Zeitlücken mit Stille überdeckt.
min_delta
Die minimale Differenz zwischen Zeitstempeln und Audiodaten (in Sekunden) zum Auslösen
Hinzufügen/Entfernen von Samples. Der Standardwert ist 0.1. Wenn Sie eine unvollständige Synchronisierung mit erhalten
dieser Filter, versuchen Sie, diesen Parameter auf 0 zu setzen.
max_komp
Die maximale Kompensation in Samples pro Sekunde. Nur relevant bei kompensieren=1. Die
Standardwert ist 500.
erste_Punkte
Angenommen, der erste PTS sollte diesen Wert haben. Die Zeitbasis beträgt 1 / Abtastrate. Dies
ermöglicht das Auffüllen/Trimmen am Anfang des Streams. Standardmäßig ist keine Annahme
über den erwarteten PTS des ersten Frames erstellt, so dass kein Auffüllen oder Trimmen erfolgt. Zum
Dies könnte beispielsweise auf 0 gesetzt werden, um den Anfang mit Stille aufzufüllen, wenn ein Audiostream
startet nach dem Videostream oder um Samples mit negativem PTS aufgrund von
Verzögerung des Encoders.
Tempo
Passen Sie das Audiotempo an.
Der Filter akzeptiert genau einen Parameter, das Audiotempo. Wenn nicht angegeben, dann die
Filter nimmt ein nominales 1.0-Tempo an. Das Tempo muss im Bereich [0.5, 2.0] liegen.
Beispiele
· Audio auf 80 % Tempo verlangsamen:
Tempo=0.8
· So beschleunigen Sie Audio auf 125% Tempo:
Tempo=1.25
atrim
Trimmen Sie die Eingabe, sodass die Ausgabe einen fortlaufenden Unterteil der Eingabe enthält.
Es akzeptiert die folgenden Parameter:
Anfang
Zeitstempel (in Sekunden) des Anfangs des beizubehaltenden Abschnitts. Dh das Hörbeispiel mit
der Zeitstempel Anfang wird das erste Sample in der Ausgabe sein.
Ende Geben Sie die Zeit des ersten Audiosamples an, das gelöscht wird, dh das Audiosample
unmittelbar vor dem mit dem Zeitstempel Ende wird die letzte Probe in der
Ausgabe.
start_pts
Das gleiche wie Anfang, außer dass diese Option den Startzeitstempel in Samples anstatt in setzt
Sekunden.
end_pts
Das gleiche wie Ende, außer dass diese Option den Endzeitstempel in Samples statt in Sekunden festlegt.
Dauer
Die maximale Dauer der Ausgabe in Sekunden.
start_sample
Die Nummer des ersten Samples, das ausgegeben werden soll.
end_sample
Die Nummer der ersten Probe, die gelöscht werden soll.
Anfang, Ende und Dauer werden als Zeitdauerspezifikationen ausgedrückt; sehen Uhrzeit
Dauer Abschnitt in ffmpeg-utils(1) manuell.
Beachten Sie, dass die ersten beiden Sätze der Start-/Endoptionen und die Dauer Option schau dir die an
Frame-Zeitstempel, während die _sample-Optionen einfach die Samples zählen, die durch die
Filter. start/end_pts und start/end_sample liefern also unterschiedliche Ergebnisse, wenn die
Zeitstempel sind falsch, ungenau oder beginnen nicht bei Null. Beachten Sie auch, dass dieser Filter nicht
ändern Sie die Zeitstempel. Wenn Sie möchten, dass die Ausgabezeitstempel bei Null beginnen, fügen Sie das
asetpts-Filter nach dem atrim-Filter.
Wenn mehrere Start- oder Endoptionen festgelegt sind, versucht dieser Filter gierig zu sein und alle zu behalten
Stichproben, die mindestens einer der angegebenen Einschränkungen entsprechen. Um nur den Teil zu behalten, der
entspricht allen Einschränkungen auf einmal, verketten Sie mehrere Atrim-Filter.
Die Standardeinstellungen sind so, dass alle Eingaben beibehalten werden. So ist es zB möglich, nur die
Endwerte, um alles vor der angegebenen Zeit zu behalten.
Beispiele:
· Alles außer der zweiten Minute der Eingabe löschen:
ffmpeg -i EINGANG -af atrim=60:120
· Bewahren Sie nur die ersten 1000 Proben auf:
ffmpeg -i EINGANG -af atrim=end_sample=1000
Bandpass
Wenden Sie einen zweipoligen Butterworth-Bandpassfilter mit Mittenfrequenz an Frequenz und
(3dB-Punkt) Bandbreite. Die csg Option wählt eine konstante Randverstärkung (Spitzenverstärkung =
Q) statt der Vorgabe: konstant 0dB Spitzenverstärkung. Der Filter rollt bei 6 dB pro Oktave ab
(20dB pro Jahrzehnt).
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Stellen Sie die Mittenfrequenz des Filters ein. Standard ist 3000.
csg Konstante Randverstärkung, wenn auf 1 eingestellt. Standardmäßig auf 0.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Geben Sie die Bandbreite eines Filters in width_type-Einheiten an.
Bandabweisung
Wenden Sie einen zweipoligen Butterworth-Bandsperrfilter mit Mittenfrequenz an Frequenz und
(3dB-Punkt) Bandbreite Breite. Der Filter rollt bei 6 dB pro Oktave (20 dB pro Dekade) ab.
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Stellen Sie die Mittenfrequenz des Filters ein. Standard ist 3000.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Geben Sie die Bandbreite eines Filters in width_type-Einheiten an.
Bass
Verstärken oder senken Sie die Bassfrequenzen (niedrigeren) des Audios mit einem zweipoligen Shelving-Filter
mit einem ähnlichen Ansprechverhalten wie die Klangregler einer Standard-HiFi-Anlage. Dies ist auch bekannt als
Shelving-Entzerrung (EQ).
Der Filter akzeptiert die folgenden Optionen:
gewinnen, g
Geben Sie die Verstärkung bei 0 Hz an. Sein nützlicher Bereich liegt zwischen -20 (für einen großen Schnitt) bis +20 (für a
großer Schub). Achten Sie auf Clipping, wenn Sie eine positive Verstärkung verwenden.
Frequenz, f
Stellen Sie die Mittenfrequenz des Filters ein und können so verwendet werden, um die
Frequenzbereich angehoben oder abgesenkt werden. Der Standardwert ist 100 Hz.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Bestimmen Sie, wie steil der Shelf-Übergang des Filters ist.
Biquad
Wenden Sie einen Biquad-IIR-Filter mit den angegebenen Koeffizienten an. Woher b0, b1, b2 und a0, a1, a2
sind die Zähler- und Nennerkoeffizienten.
bs2b
Bauer-Stereo-zu-Binaural-Transformation, die das Hören von Stereo über Kopfhörer verbessert
Audioaufzeichnungen.
Es akzeptiert die folgenden Parameter:
profile
Vordefinierte Quervorschubebene.
Standard
Standardstufe (fcut=700, feed=50).
cmoy
Chu Moy-Schaltung (fcut=700, feed=60).
jmeier
Jan Meier Schaltung (fcut=650, feed=95).
fcut
Cut-Frequenz (in Hz).
Feed
Speisepegel (in Hz).
Kanalkarte
Ordnen Sie Eingangskanäle neuen Positionen zu.
Es akzeptiert die folgenden Parameter:
Kanal_Layout
Das Kanallayout des Ausgabestreams.
Karte Ordnen Sie Kanäle vom Eingang zum Ausgang zu. Das Argument ist eine durch '|' getrennte Liste von Zuordnungen,
jeweils in der "in_channel-out_channel" or in_channel Form. in_channel kann entweder das sein
Name des Eingangskanals (zB FL für vorne links) oder dessen Index im Eingangskanal
Layout. out_channel ist der Name des Ausgabekanals oder sein Index in der Ausgabe
Kanal-Layout. Wenn out_channel nicht gegeben ist, ist es implizit ein Index, beginnend
mit null und für jede Abbildung um eins erhöht.
Wenn kein Mapping vorhanden ist, ordnet der Filter implizit die Eingangskanäle dem Ausgang zu
Kanäle unter Beibehaltung von Indizes.
Angenommen beispielsweise eine 5.1+Downmix-Eingangs-MOV-Datei,
ffmpeg -i in.mov -filter 'channelmap=map=DL-FL|DR-FR' out.wav
erstellt eine als Stereo markierte Ausgabe-WAV-Datei aus den Downmix-Kanälen des Eingangs.
So beheben Sie ein 5.1-WAV, das falsch in der nativen Kanalreihenfolge von AAC codiert ist
ffmpeg -i in.wav -filter 'channelmap=1|2|0|5|3|4:5.1' out.wav
Kanalspaltung
Teilen Sie jeden Kanal eines Eingangsaudiostreams in einen separaten Ausgangsstream auf.
Es akzeptiert die folgenden Parameter:
Kanal_Layout
Das Kanallayout des Eingabestreams. Die Vorgabe ist "Stereo".
Angenommen, eine MP3-Datei mit Stereoeingang
ffmpeg -i in.mp3 -filter_complexchannelsplitout.mkv
erstellt eine Matroska-Ausgabedatei mit zwei Audiostreams, von denen einer nur den linken enthält
Kanal und der andere der rechte Kanal.
Teilen Sie eine 5.1 WAV-Datei in Pro-Kanal-Dateien auf:
ffmpeg -i in.wav -filter_komplex
'channelsplit=channel_layout=5.1[FL][FR][FC][LFE][SL][SR]'
-map '[FL]' front_left.wav -map '[FR]' front_right.wav -map '[FC]'
front_center.wav -map '[LFE]' lfe.wav -map '[SL]' side_left.wav -map '[SR]'
side_right.wav
Chor
Fügen Sie dem Audio einen Chorus-Effekt hinzu.
Kann eine einzelne Stimme wie einen Chorus klingen lassen, kann aber auch auf Instrumentierung angewendet werden.
Chorus ähnelt einem Echoeffekt mit einer kurzen Verzögerung, während bei Echo die Verzögerung
konstant, mit Chorus, wird durch Sinus- oder Dreiecksmodulation variiert. Die
Modulationstiefe definiert den Bereich, in dem das modulierte Delay vor oder nach dem
verzögern. Daher ertönt der verzögerte Ton langsamer oder schneller, das ist der verzögerte Ton
um das Original gestimmt, wie in einem Refrain, in dem einige Vocals leicht verstimmt sind.
Es akzeptiert die folgenden Parameter:
in_gain
Eingangsverstärkung einstellen. Der Standardwert ist 0.4.
out_gain
Ausgangsverstärkung einstellen. Der Standardwert ist 0.4.
Verzögerungen
Legen Sie Verzögerungen fest. Eine typische Verzögerung beträgt etwa 40 ms bis 60 ms.
verfällt
Set verfällt.
Geschwindigkeiten
Geschwindigkeiten einstellen.
Tiefe
Tiefen einstellen.
Beispiele
· Eine einzelne Verzögerung:
chorus=0.7:0.9:55:0.4:0.25:2
· Zwei Verzögerungen:
chorus=0.6:0.9:50|60:0.4|0.32:0.25|0.4:2|1.3
· Voller klingender Chorus mit drei Delays:
chorus=0.5:0.9:50|60|40:0.4|0.32|0.3:0.25|0.4|0.3:2|2.3|1.3
Kompanie
Komprimieren oder erweitern Sie den Dynamikbereich des Audios.
Es akzeptiert die folgenden Parameter:
Attacken
verfällt
Eine Liste der Zeiten in Sekunden für jeden Kanal, über die der momentane Pegel des
Eingangssignal wird gemittelt, um seine Lautstärke zu bestimmen. Attacken bezieht sich auf Volumenzunahme
und verfällt bezieht sich auf die Abnahme des Volumens. In den meisten Situationen ist die Angriffszeit
(Reaktion auf lauter werdendes Audio) sollte kürzer als die Decay-Zeit sein, weil
Das menschliche Ohr reagiert empfindlicher auf plötzliches lautes Audio als auf plötzliches leises Audio. Ein typisches
Der Attack-Wert beträgt 0.3 Sekunden und der typische Decay-Wert 0.8 Sekunden. Wenn
Die angegebene Anzahl von Attacks & Decays ist niedriger als die Anzahl der Kanäle, der letzte Satz
Attack/Decay wird für alle verbleibenden Kanäle verwendet.
Punkte
Eine Liste von Punkten für die Übertragungsfunktion, angegeben in dB relativ zum Maximum
mögliche Signalamplitude. Jede Schlüsselpunktliste muss wie folgt definiert werden
Syntax: "x0/y0|x1/y1|x2/y2|..." oder "x0/y0 x1/y1 x2/y2 ...."
Die Eingabewerte müssen streng aufsteigend sein, aber die Übertragungsfunktion tut es
müssen nicht monoton steigend sein. Der Punkt „0/0“ wird angenommen, kann aber überschrieben werden
(durch "0/out-dBn"). Typische Werte für die Übertragungsfunktion sind "-70/-70|-60/-20".
weiches Knie
Stellen Sie den Kurvenradius in dB für alle Gelenke ein. Der Standardwert ist 0.01.
gewinnen
Stellen Sie die zusätzliche Verstärkung in dB ein, die an allen Punkten der Übertragungsfunktion angewendet werden soll.
Dies ermöglicht eine einfache Einstellung der Gesamtverstärkung. Es ist standardmäßig 0.
Volumen
Stellen Sie eine Anfangslautstärke in dB ein, die für jeden Kanal angenommen werden soll, wenn die Filterung beginnt.
Dadurch kann der Anwender zunächst einen Nennfüllstand liefern, so dass beispielsweise a
eine sehr große Verstärkung wird nicht auf die anfänglichen Signalpegel angewendet, bevor die Kompandierung abgeschlossen ist
in Betrieb genommen. Ein typischer Wert für anfangs leises Audio ist -90 dB. Es
standardmäßig auf 0.
verzögern
Legen Sie eine Verzögerung in Sekunden fest. Das Eingangsaudio wird sofort analysiert, aber das Audio wird verzögert
bevor sie dem Lautstärkeregler zugeführt werden. Angeben einer Verzögerung ungefähr gleich der
Attack/Decay-Zeiten ermöglichen es dem Filter, effektiv prädiktiv zu arbeiten, anstatt
reaktiver Modus. Es ist standardmäßig 0.
Beispiele
· Machen Sie Musik mit sowohl leisen als auch lauten Passagen, die sich zum Hören in lauter Umgebung eignen
Umgebung:
compand=.3|.3:1|1:-90/-60|-60/-40|-40/-30|-20/-20:6:0:-90:0.2
Ein weiteres Beispiel für Audio mit Flüster- und Explosionsanteilen:
compand=0|0:1|1:-90/-900|-70/-70|-30/-9|0/-3:6:0:0:0
· Ein Noise Gate, wenn das Rauschen niedriger ist als das Signal:
compand=.1|.1:.2|.2:-900/-900|-50.1/-900|-50/-50:.01:0:-90:.1
· Hier ist ein weiteres Noise Gate, dieses Mal, wenn das Rauschen einen höheren Pegel hat als der
Signal (was es in gewisser Weise ähnlich wie Squelch macht):
compand=.1|.1:.1|.1:-45.1/-45.1|-45/-900|0/-900:.01:45:-90:.1
dcshift
Wenden Sie eine DC-Verschiebung auf das Audio an.
Dies kann nützlich sein, um einen DC-Offset zu entfernen (verursacht möglicherweise durch ein Hardwareproblem im
Aufnahmekette) aus dem Audio. Der Effekt eines DC-Offsets reduziert den Headroom und somit
Volumen. Die Statistiken Filter kann verwendet werden, um zu bestimmen, ob ein Signal einen DC-Offset hat.
verschieben
Legen Sie die DC-Verschiebung fest, der zulässige Bereich ist [-1, 1]. Es gibt den Betrag an, um den die
Audio.
Begrenzerverstärkung
Optional. Es sollte einen Wert von viel weniger als 1 haben (z. B. 0.05 oder 0.02) und wird verwendet, um
Clipping verhindern.
Dynaudnorm
Dynamischer Audionormalizer.
Dieser Filter wendet eine gewisse Verstärkung auf das Eingangsaudio an, um seinen Spitzenwert zu erreichen
Magnitude auf einen Zielpegel (zB 0 dBFS). Im Gegensatz zu "einfacheren"
Normalisierungsalgorithmen passt der Dynamic Audio Normalizer *dynamisch* die Verstärkung neu an
Faktor zum Eingangsaudio. Dies ermöglicht eine zusätzliche Verstärkung in den "ruhigen" Abschnitten von
das Audio, während Verzerrungen oder das Abschneiden der "lauten" Abschnitte vermieden werden. Mit anderen Worten: Die
Dynamic Audio Normalizer gleicht die Lautstärke leiser und lauter Passagen aus, in der
spüren, dass die Lautstärke jedes Abschnitts auf den gleichen Zielpegel gebracht wird. Beachten Sie jedoch,
dass der Dynamic Audio Normalizer dieses Ziel *ohne* Anwendung von "Dynamikbereich" erreicht
komprimieren". Es behält 100 % des Dynamikbereichs *innerhalb* jedes Abschnitts des Audios bei
Datei.
f Legen Sie die Framelänge in Millisekunden fest. Im Bereich von 10 bis 8000 Millisekunden. Standard
beträgt 500 Millisekunden. Der Dynamic Audio Normalizer verarbeitet das Eingangsaudio in kleinen
Blöcke, die als Frames bezeichnet werden. Dies ist erforderlich, da eine Spitzengröße keine
Bedeutung für nur einen einzelnen Abtastwert. Stattdessen müssen wir den Peak bestimmen
Betrag für eine zusammenhängende Folge von Abtastwerten. Während ein "Standard"-Normalisierer
würde einfach die Spitzengröße der gesamten Datei verwenden, den Dynamic Audio Normalizer
bestimmt die Spitzengröße individuell für jeden Frame. Die Länge eines Rahmens beträgt
in Millisekunden angegeben. Standardmäßig verwendet der Dynamic Audio Normalizer einen Frame
Länge von 500 Millisekunden, was bei den meisten Dateien zu guten Ergebnissen führt.
Beachten Sie, dass die genaue Framelänge in Anzahl der Samples bestimmt wird
automatisch, basierend auf der Abtastrate der einzelnen Audio-Eingangsdatei.
g Legen Sie die Fenstergröße des Gauß-Filters fest. Im Bereich von 3 bis 301, muss eine ungerade Zahl sein.
Der Standardwert ist 31. Der wahrscheinlich wichtigste Parameter des Dynamic Audio Normalizer
ist die "Fenstergröße" des Gaußschen Glättungsfilters. Die Fenstergröße des Filters beträgt
in Frames angegeben, zentriert um den aktuellen Frame. Der Einfachheit halber,
das muss eine ungerade Zahl sein. Folglich berücksichtigt der Standardwert von 31
den aktuellen Frame sowie die 15 vorhergehenden Frames und die 15 nachfolgenden Frames.
Die Verwendung eines größeren Fensters führt zu einem stärkeren Glättungseffekt und damit zu weniger Verstärkung
Variation, dh langsamere Verstärkungsanpassung. Umgekehrt führt die Verwendung eines kleineren Fensters zu
einen schwächeren Glättungseffekt und damit mehr Gain-Variation, dh schnellere Gain
Anpassung. Mit anderen Worten, je mehr Sie diesen Wert erhöhen, desto mehr Dynamik
Audio Normalizer verhält sich wie ein "herkömmlicher" Normalisierungsfilter. Auf der
im Gegenteil, je mehr Sie diesen Wert verringern, desto stärker wird der Dynamic Audio Normalizer
verhalten sich wie ein Dynamikkompressor.
p Stellen Sie den Ziel-Spitzenwert ein. Dies gibt die höchstzulässige Magnitudenstufe für
der normalisierte Audioeingang. Dieser Filter versucht, sich der Zielspitzengröße anzunähern
so nah wie möglich, stellt aber gleichzeitig sicher, dass die normalisierten
Signal wird niemals die Spitzengröße überschreiten. Der maximale lokale Verstärkungsfaktor eines Frames ist
direkt von der Zielspitzengröße auferlegt. Der Standardwert ist 0.95 und somit
lässt einen Headroom von 5%*. Es wird nicht empfohlen, diesen Wert zu überschreiten.
m Stellen Sie den maximalen Verstärkungsfaktor ein. Im Bereich von 1.0 bis 100.0. Der Standardwert ist 10.0. Die Dynamik
Audio Normalizer bestimmt den maximal möglichen (lokalen) Verstärkungsfaktor für jeden Eingang
Frame, dh der maximale Verstärkungsfaktor, der nicht zu Clipping oder Verzerrung führt.
Der maximale Verstärkungsfaktor wird durch die Abtastung mit der höchsten Größe des Rahmens bestimmt.
Der Dynamic Audio Normalizer begrenzt jedoch zusätzlich die maximale Verstärkung des Frames
Faktor um einen vorgegebenen (globalen) maximalen Verstärkungsfaktor. Dies geschieht, um zu vermeiden
übermäßige Verstärkungsfaktoren in "stillen" oder fast lautlosen Frames. Standardmäßig ist das Maximum
Verstärkungsfaktor ist 10.0. Für die meisten Eingänge sollte der Standardwert ausreichend sein und es
Normalerweise wird nicht empfohlen, diesen Wert zu erhöhen. Für die Eingabe mit einem extrem
bei geringer Gesamtlautstärke kann es erforderlich sein, noch höhere Verstärkungsfaktoren zuzulassen. Notiz,
dass der Dynamic Audio Normalizer jedoch nicht einfach einen "harten" Schwellenwert anwendet
(dh Cut-off-Werte über dem Schwellenwert). Stattdessen eine "Sigmoid"-Schwellenfunktion
Wird angewendet werden. Auf diese Weise nähern sich die Verstärkungsfaktoren sanft dem Schwellenwert
Wert, aber überschreiten Sie diesen Wert nie.
r Legen Sie den Ziel-RMS fest. Im Bereich von 0.0 bis 1.0. Standard ist 0.0 - deaktiviert. Standardmäßig,
der Dynamic Audio Normalizer führt eine "Peak"-Normalisierung durch. Dies bedeutet, dass die
Der maximale lokale Verstärkungsfaktor für jeden Frame wird (nur) durch den höchsten . des Frames definiert
Größenordnung Probe. Auf diese Weise können die Proben so weit wie möglich amplifiziert werden, ohne dass
Überschreitung des maximalen Signalpegels, dh ohne Clipping. Optional kann jedoch die
Dynamic Audio Normalizer kann auch den quadratischen Mittelwert des Frames berücksichtigen,
abgekürzt RMS. In der Elektrotechnik wird der RMS häufig verwendet, um die
Leistung eines zeitveränderlichen Signals. Es wird daher davon ausgegangen, dass der RMS besser ist
Annäherung an die "wahrgenommene Lautheit" als nur auf den Peak des Signals zu schauen
Größe. Folglich wird durch Einstellen aller Frames auf einen konstanten RMS-Wert ein einheitliches
"wahrgenommene Lautheit" festgestellt werden. Wenn ein Ziel-RMS-Wert angegeben wurde, a
Der lokale Verstärkungsfaktor des Rahmens ist als der Faktor definiert, der genau das ergeben würde
Effektivwert. Beachten Sie jedoch, dass der maximale lokale Verstärkungsfaktor immer noch durch
das Sample mit der höchsten Größe des Frames, um Clipping zu vermeiden.
n Aktivieren Sie die Kanalkopplung. Standardmäßig ist aktiviert. Standardmäßig ist das dynamische Audio
Normalizer verstärkt alle Kanäle um den gleichen Betrag. Das bedeutet den gleichen Gewinn
Faktor wird auf alle Kanäle angewendet, dh der maximal mögliche Verstärkungsfaktor ist
bestimmt durch den "lautesten" Kanal. Bei manchen Aufnahmen kann es jedoch vorkommen, dass
die Lautstärke der verschiedenen Kanäle ist ungleichmäßig, zB kann ein Kanal "leiser" sein als
die Anderen). In diesem Fall kann diese Option verwendet werden, um den Kanal zu deaktivieren
Kupplung. Auf diese Weise wird der Verstärkungsfaktor für jeden Kanal unabhängig bestimmt,
hängt nur von der stärksten Abtastung des einzelnen Kanals ab. Dies ermöglicht
Harmonisierung der Lautstärke der verschiedenen Kanäle.
c Aktivieren Sie die DC-Bias-Korrektur. Standardmäßig ist deaktiviert. Ein Audiosignal (in der Zeit
domain) ist eine Folge von Beispielwerten. Im Dynamic Audio Normalizer sind diese Beispiele
Werte werden im Bereich von -1.0 bis 1.0 dargestellt, unabhängig von der ursprünglichen Eingabe
Format. Normalerweise sollte das Audiosignal oder die "Wellenform" um die Null zentriert sein
Punkt. Das heißt, wenn wir den Mittelwert aller Stichproben in einer Datei berechnen, oder in a
Einzelbild, dann sollte das Ergebnis 0.0 oder zumindest sehr nahe an diesem Wert sein. Wenn,
es gibt jedoch eine signifikante Abweichung des Mittelwertes von 0.0, entweder in
positive oder negative Richtung, dies wird als DC-Bias oder DC-Offset bezeichnet. Seit einem
DC-Bias ist eindeutig unerwünscht, der Dynamic Audio Normalizer bietet optional DC-Bias
Korrektur. Wenn die DC-Bias-Korrektur aktiviert ist, wird der Dynamic Audio Normalizer
Bestimmen Sie den Mittelwert oder "DC-Korrektur"-Offset jedes Eingaberahmens und subtrahieren
dieser Wert aus allen Sample-Werten des Frames, der sicherstellt, dass diese Samples
wieder um 0.0 zentriert. Um auch "Lücken" an den Rahmengrenzen zu vermeiden,
Die Offset-Werte der DC-Korrektur werden glatt zwischen benachbarten Frames interpoliert.
b Aktivieren Sie den alternativen Begrenzungsmodus. Standardmäßig ist deaktiviert. Das dynamische Audio
Der Normalizer berücksichtigt eine bestimmte Umgebung um jeden Frame. Das beinhaltet
die vorhergehenden Frames sowie die nachfolgenden Frames. Aber für die "Grenze"
Frames, die sich ganz am Anfang und ganz am Ende der Audiodatei befinden, nicht alle
Nachbarrahmen sind vorhanden. Insbesondere für die ersten paar Frames im
Audiodatei, die vorhergehenden Frames sind nicht bekannt. Und in ähnlicher Weise für die letzten paar
Frames in der Audiodatei sind die nachfolgenden Frames nicht bekannt. Also die Frage
ergibt sich, welche Verstärkungsfaktoren für die fehlenden Frames im "Boundary" angenommen werden sollen
Region. Der Dynamic Audio Normalizer implementiert zwei Modi, um mit dieser Situation umzugehen.
Der Standard-Boundary-Modus geht von einem Verstärkungsfaktor von genau 1.0 für die fehlenden Frames aus,
was zu einem sanften "Einblenden" und "Ausblenden" am Anfang und am Ende des
Eingabe bzw.
s Stellen Sie den Komprimierungsfaktor ein. Im Bereich von 0.0 bis 30.0. Der Standardwert ist 0.0. Standardmäßig ist die
Dynamic Audio Normalizer wendet keine "herkömmliche" Komprimierung an. Dies bedeutet, dass
Signalspitzen werden nicht beschnitten und somit bleibt der volle Dynamikumfang erhalten
in jedem Ortsteil. In einigen Fällen kann es jedoch wünschenswert sein, zu kombinieren
der Normalisierungsalgorithmus des Dynamic Audio Normalizer mit einem "traditionelleren"
Kompression. Dazu bietet der Dynamic Audio Normalizer eine optionale
Kompressionsfunktion (Schwellenwert). Wenn (und nur wenn) die Komprimierungsfunktion . ist
aktiviert, werden alle Eingangsframes zuvor von einer Soft-Knie-Schwellenwertfunktion verarbeitet
zum eigentlichen Normalisierungsprozess. Einfach ausgedrückt, die Schwellenwertfunktion wird
Beschneiden Sie alle Stichproben, deren Größe einen bestimmten Schwellenwert überschreitet. Allerdings ist die
Dynamic Audio Normalizer wendet nicht einfach einen festen Schwellenwert an. Stattdessen ist die
Schwellenwert wird für jeden einzelnen Frame angepasst. Im Allgemeinen kleiner
Parameter führen zu einer stärkeren Kompression und umgekehrt. Werte unter 3.0 sind nicht
empfohlen, da hörbare Verzerrungen auftreten können.
Ohrenschmalz
Erleichtern Sie das Hören von Audio über Kopfhörer.
Dieser Filter fügt dem 44.1-kHz-Stereo-Audio (dh im Audio-CD-Format) „Cues“ hinzu, sodass beim
über Kopfhörer abgehört wird das Stereobild aus dem Inneren Ihres Kopfes (Standard für
Kopfhörer) nach außen und vor den Hörer (Standard bei Lautsprechern).
Von SoX portiert.
Ausgleich
Wenden Sie einen zweipoligen Peaking-Entzerrungsfilter (EQ) an. Bei diesem Filter wird der Signalpegel bei
und um eine ausgewählte Frequenz erhöht oder verringert werden, während (im Gegensatz zu Bandpass und
Bandsperrfilter), die bei allen anderen Frequenzen unverändert ist.
Um komplexe Entzerrungskurven zu erzeugen, kann dieser Filter mehrfach angegeben werden,
jeweils mit einer anderen Mittenfrequenz.
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Stellen Sie die Mittenfrequenz des Filters in Hz ein.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Geben Sie die Bandbreite eines Filters in width_type-Einheiten an.
gewinnen, g
Stellen Sie die erforderliche Verstärkung oder Dämpfung in dB ein. Achten Sie bei der Verwendung eines Positivs auf Clipping
zu gewinnen.
Beispiele
· 10 dB bei 1000 Hz dämpfen, mit einer Bandbreite von 200 Hz:
Equalizer=f=1000:width_type=h:width=200:g=-10
· 2 dB Verstärkung bei 1000 Hz mit Q 1 anwenden und 5 dB bei 100 Hz mit Q 2 dämpfen:
equalizer=f=1000:width_type=q:width=1:g=2,equalizer=f=100:width_type=q:width=2:g=-5
Flanger
Wenden Sie einen Flanger-Effekt auf das Audio an.
Der Filter akzeptiert die folgenden Optionen:
verzögern
Stellen Sie die Basisverzögerung in Millisekunden ein. Bereich von 0 bis 30. Der Standardwert ist 0.
Tiefe
Legen Sie die zusätzliche Sweep-Verzögerung in Millisekunden fest. Bereich von 0 bis 10. Der Standardwert ist 2.
regen
Prozentuale Regeneration einstellen (verzögerte Signalrückmeldung). Bereich von -95 bis 95. Standard
Wert ist 0.
Breite
Stellen Sie den Prozentsatz des verzögerten Signals ein, das mit dem Original gemischt wird. Bereich von 0 bis 100. Standard
Wert ist 71.
Geschwindigkeit
Sweeps pro Sekunde (Hz) einstellen. Bereich von 0.1 bis 10. Der Standardwert ist 0.5.
gestalten
Gepfeilte Wellenform einstellen, kann sein dreieckig or sinusförmig. Standardwert ist sinusförmig.
Phase
Stellen Sie die prozentuale Verschiebung der Wobbelwelle für Mehrkanal ein. Bereich von 0 bis 100. Standardwert
ist 25.
interp
Delay-Line-Interpolation einstellen, linear or quadratisch. Standard ist linear.
Hochpass
Wenden Sie einen Hochpassfilter mit einer Punktfrequenz von 3 dB an. Der Filter kann entweder einpolig,
oder zweipolig (Standard). Der Filter rollt bei 6dB pro Pol pro Oktave (20dB pro
Pol pro Jahrzehnt).
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Frequenz in Hz einstellen. Standard ist 3000.
Stangen, p
Anzahl der Pole einstellen. Standard ist 2.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Geben Sie die Bandbreite eines Filters in width_type-Einheiten an. Gilt nur für Doppelpol
Filter. Der Standardwert ist 0.707q und gibt eine Butterworth-Antwort aus.
join
Verbinden Sie mehrere Eingabestreams zu einem Mehrkanalstream.
Es akzeptiert die folgenden Parameter:
Eingänge
Die Anzahl der Eingabestreams. Es ist standardmäßig auf 2.
Kanal_Layout
Das gewünschte Ausgangskanal-Layout. Es ist standardmäßig auf Stereo eingestellt.
Karte Ordnen Sie Kanäle von den Eingängen zum Ausgang zu. Das Argument ist eine durch '|' getrennte Liste von Zuordnungen,
jeweils in der "input_idx.in_channel-out_channel" Form. input_idx ist der 0-basierte Index von
der Eingangsstrom. in_channel kann entweder der Name des Eingangskanals sein (zB FL für
vorne links) oder seinen Index im angegebenen Eingabestrom. out_channel ist der Name des
Ausgangskanal.
Der Filter versucht, die Zuordnungen zu erraten, wenn sie nicht explizit angegeben werden. Es
tut dies, indem zuerst versucht wird, einen nicht verwendeten passenden Eingangskanal zu finden, und wenn dies fehlschlägt
wählt den ersten ungenutzten Eingangskanal.
Verbinden Sie 3 Eingänge (mit richtig eingestellten Kanallayouts):
ffmpeg -i INPUT1 -i INPUT2 -i INPUT3 -filter_complex join=inputs=3 AUSGANG
Erstellen Sie eine 5.1-Ausgabe aus 6 Einzelkanal-Streams:
ffmpeg -i fl -i fr -i fc -i sl -i sr -i lfe -filter_complex
'join=inputs=6:channel_layout=5.1:map=0.0-FL|1.0-FR|2.0-FC|3.0-SL|4.0-SR|5.0-LFE'
ladspa
Laden Sie ein LADSPA-Plugin (Linux Audio Developer's Simple Plugin API).
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie FFmpeg mit "--enable-ladspa" konfigurieren.
Datei, f
Gibt den Namen der zu ladenden LADSPA-Plugin-Bibliothek an. Wenn die Umgebungsvariable
LADSPA_PFAD definiert ist, wird das LADSPA-Plugin in jedem der Verzeichnisse gesucht
angegeben durch die durch Doppelpunkte getrennte Liste in LADSPA_PFAD, sonst im Standard LADSPA
Pfade, die in dieser Reihenfolge sind: HOME/.ladspa/lib/, /usr/local/lib/ladspa/,
/usr/lib/ladspa/.
Plugin, p
Gibt das Plugin innerhalb der Bibliothek an. Einige Bibliotheken enthalten nur ein Plugin, aber
andere enthalten viele davon. Wenn dies nicht eingestellt ist, listet der Filter alle verfügbaren Plugins auf
innerhalb der angegebenen Bibliothek.
Kontrollen, c
Setzen Sie das '|' getrennte Liste von Steuerelementen, die null oder mehr Gleitkommawerte sind
die das Verhalten des geladenen Plugins bestimmen (zum Beispiel Delay, Threshold oder
gewinnen). Steuerelemente müssen mit der folgenden Syntax definiert werden:
c0=value0|c1=value1|c2=value2|..., wo wert ist der Wert auf dem i-te Kontrolle.
If Steuerung auf "Hilfe" gesetzt ist, sind alle verfügbaren Steuerelemente und ihre gültigen Bereiche
gedruckt.
Beispielrate, s
Geben Sie die Abtastrate an, Standard ist 44100. Wird nur verwendet, wenn das Plugin keine Eingänge hat.
nb_proben, n
Legen Sie die Anzahl der Samples pro Kanal und jedes Ausgabeframe fest, der Standardwert ist 1024. Nur
Wird verwendet, wenn das Plugin keine Eingänge hat.
Dauer, d
Legen Sie die Mindestdauer der Audioquelle fest. Sehen Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell für die akzeptierte Syntax. Beachten Sie, dass die resultierende Dauer möglicherweise
länger als die angegebene Dauer sein, da das generierte Audio immer am
Ende eines kompletten Rahmens. Wenn nicht angegeben oder die angegebene Dauer negativ ist, wird die
Audio soll für immer generiert werden. Wird nur verwendet, wenn das Plugin null Eingänge hat.
Beispiele
· Listen Sie alle verfügbaren Plugins in der AMP-Bibliothek (LADSPA-Beispiel-Plugin) auf:
ladspa=Datei=amp
· Listen Sie alle verfügbaren Steuerelemente und ihre gültigen Bereiche für das "vcf_notch"-Plugin von "VCF" auf
Bibliothek:
ladspa=f=vcf:p=vcf_notch:c=Hilfe
· Simulieren Sie Audiogeräte von geringer Qualität mit dem Plugin "Computer Music Toolkit" (CMT)
Bibliothek:
ladspa=file=cmt:plugin=lofi:controls=c0=22|c1=12|c2=12
· Fügen Sie dem Audio mit TAP-Plugins (Toms Audio Processing Plugins) Nachhall hinzu:
ladspa=file=tap_reverb:tap_reverb
· Weißes Rauschen mit 0.2 Amplitude erzeugen:
ladspa=file=cmt:noise_source_white:c=c0=.2
· Erzeuge 20 bpm Klicks mit dem Plugin "C* Click - Metronome" aus dem "C* Audio Plugin"
Suite" (CAPS) Bibliothek:
ladspa=file=caps:Klick:c=c1=20'
· Wenden Sie den Effekt "C* Eq10X2 - Stereo 10-Band-Equalizer" an:
ladspa=caps:Eq10X2:c=c0=-48|c9=-24|c3=12|c4=2
Befehle
Dieser Filter unterstützt die folgenden Befehle:
cN ändern Sie die N-ten Kontrollwert.
Wenn der angegebene Wert nicht gültig ist, wird er ignoriert und der vorherige Wert beibehalten.
Tiefpass
Wenden Sie einen Tiefpassfilter mit einer Punktfrequenz von 3 dB an. Der Filter kann entweder einpolig oder
zweipolig (Standard). Der Filter rollt bei 6dB pro Pol pro Oktave ab (20dB pro Pol
pro Jahrzehnt).
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Frequenz in Hz einstellen. Standard ist 500.
Stangen, p
Anzahl der Pole einstellen. Standard ist 2.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Geben Sie die Bandbreite eines Filters in width_type-Einheiten an. Gilt nur für Doppelpol
Filter. Der Standardwert ist 0.707q und gibt eine Butterworth-Antwort aus.
Pfanne
Mischen Sie Kanäle mit bestimmten Verstärkungsstufen. Der Filter akzeptiert das Ausgangskanallayout
gefolgt von einer Reihe von Kanaldefinitionen.
Dieser Filter wurde auch entwickelt, um die Kanäle eines Audiostreams effizient neu zuzuordnen.
Der Filter akzeptiert Parameter der Form: "l|outdef|outdef|..."
l Ausgangskanallayout oder Anzahl der Kanäle
outdef
Spezifikation des Ausgangskanals in der Form:
"out_name=[gewinnen*]in_name[+[gewinnen*]in_name...]"
out_name
Ausgangskanal zu definieren, entweder einen Kanalnamen (FL, FR, etc.) oder eine Kanalnummer
(c0, c1, usw.)
gewinnen
multiplikativer Koeffizient für den Kanal, 1 bei unveränderter Lautstärke
in_name
zu verwendender Eingangskanal, siehe out_name für Details; Es ist nicht möglich, benannte und zu mischen
nummerierte Eingangskanäle
Wenn das `=' in einer Kanalangabe durch `<' ersetzt wird, dann die Verstärkung dafür
Spezifikation wird renormiert, so dass die Summe 1 ist, wodurch Clipping-Rauschen vermieden werden.
Vermischung Beispiele
Wenn Sie beispielsweise von Stereo auf Mono heruntermischen möchten, jedoch mit einem größeren Faktor für die
linker Kanal:
pan=1c|c0=0.9*c0+0.1*c1
Ein benutzerdefinierter Downmix zu Stereo, der automatisch für 3-, 4-, 5- und 7-Kanäle funktioniert
umgeben:
pan=stereo| FL < FL + 0.5*FC + 0.6*BL + 0.6*SL | FR < FR + 0.5*FC + 0.6*BR + 0.6*SR
Beachten Sie, dass ffmpeg integriert ein Standard-Down-Mix- (und -Up-Mix-) -System, das
bevorzugt (siehe Option "-ac"), es sei denn, Sie haben sehr spezielle Anforderungen.
Neuzuordnung Beispiele
Die Neuzuordnung des Kanals ist nur dann wirksam, wenn:
*
*
Wenn alle diese Bedingungen erfüllt sind, benachrichtigt der Filter den Benutzer ("Reinkanal
Mapping erkannt") und verwenden Sie eine optimierte und verlustfreie Methode, um die Neuzuordnung durchzuführen.
Wenn Sie beispielsweise eine 5.1-Quelle haben und einen Stereo-Audiostream wünschen, indem Sie das Extra weglassen
Kanäle:
pan="stereo| c0=FL | c1=FR"
Bei gleicher Quelle können Sie auch die Kanäle vorne links und vorne rechts umschalten und behalten
das Layout des Eingangskanals:
pan="5.1| c0=c1 | c1=c0 | c2=c2 | c3=c3 | c4=c4 | c5=c5"
Wenn der Eingang ein Stereo-Audiostream ist, können Sie den vorderen linken Kanal stumm schalten (und trotzdem behalten
das Stereo-Kanal-Layout) mit:
pan="stereo|c1=c1"
Immer noch mit einem Stereo-Audiostream-Eingang können Sie den rechten Kanal sowohl vorne links kopieren
und rechts:
pan="stereo| c0=FR | c1=FR"
noch einmal spielen
ReplayGain-Scannerfilter. Dieser Filter nimmt einen Audiostream als Eingabe und gibt ihn aus
unverändert. Am Ende der Filterung werden "track_gain" und "track_peak" angezeigt.
resample
Konvertieren Sie das Audio-Sample-Format, die Sample-Rate und das Kanal-Layout. Es soll nicht sein
direkt verwendet.
Seitenkettenkomprimierung
Dieser Filter verhält sich wie ein normaler Kompressor, kann aber das erkannte Signal komprimieren
zweites Eingangssignal verwenden. Es benötigt zwei Eingabeströme und gibt einen Ausgabestrom zurück.
Der erste Eingangsstrom wird abhängig vom zweiten Stromsignal verarbeitet. Die gefilterte
Das Signal kann dann in späteren Verarbeitungsstufen mit anderen Filtern gefiltert werden. Sehen Pfanne und
eine Zusammenführung Filter.
Der Filter akzeptiert die folgenden Optionen:
Schwelle
Wenn ein Signal des zweiten Streams über diesen Pegel ansteigt, beeinflusst dies die Verstärkungsreduzierung
des ersten Stroms. Standardmäßig ist 0.125. Der Bereich liegt zwischen 0.00097563 und 1.
Verhältnis
Stellen Sie ein Verhältnis ein, um das das Signal reduziert wird. 1:2 bedeutet, dass bei einer Erhöhung des Pegels um 4dB
oberhalb des Schwellenwerts liegt er nach der Reduzierung nur noch 2 dB darüber. Standard ist 2.
Der Bereich liegt zwischen 1 und 20.
Attacke
Millisekunden, die das Signal über den Schwellenwert ansteigen muss, bevor die Verstärkung erreicht wird
Reduktion beginnt. Der Standardwert ist 20. Der Bereich liegt zwischen 0.01 und 2000.
Release
Millisekunden, die das Signal unter den Schwellenwert fallen muss, bevor die Reduzierung erfolgt
wieder abgenommen. Der Standardwert ist 250. Der Bereich liegt zwischen 0.01 und 9000.
Make-up
Stellen Sie den Betrag ein, um den das Signal nach der Verarbeitung verstärkt wird. Standard ist 2.
Der Bereich reicht von 1 bis 64.
Knie
Biegen Sie das scharfe Knie um den Schwellenwert, um die Verstärkungsreduktion sanfter einzugeben.
Der Standardwert ist 2.82843. Der Bereich liegt zwischen 1 und 8.
Link
Wählen Sie, ob der "durchschnittliche" Pegel zwischen allen Kanälen des Side-Chain-Streams oder der
ein lauter("maximum") Kanal des Sidechain-Streams beeinflusst die Reduzierung. Standard ist
"Durchschnitt".
Erkennung
Soll bei "peak" das genaue Signal genommen werden oder bei "rms" ein RMS-Signal.
Standard ist "rms", was hauptsächlich glatter ist.
Beispiele
· Vollständiges ffmpeg-Beispiel mit 2 Audioeingängen, der erste Eingang wird je nach komprimiert
Signal des 2. Eingangs und später komprimiertes Signal, das mit dem 2. Eingang zusammengeführt werden soll:
ffmpeg -i main.flac -i sidechain.flac -filter_complex "[1:a]asplit=2[sc][mix];[0:a][sc]sidechaincompress[compr];[compr][mix]amerge"
Stilledetektieren
Stille in einem Audiostream erkennen.
Dieser Filter protokolliert eine Nachricht, wenn er erkennt, dass die Eingangslautstärke kleiner oder gleich ist
ein Rauschtoleranzwert für eine Dauer größer oder gleich dem minimal erkannten Rauschen
Dauer.
Die gedruckten Zeiten und Dauer werden in Sekunden angegeben.
Der Filter akzeptiert die folgenden Optionen:
Dauer, d
Legen Sie die Dauer der Stille bis zur Benachrichtigung fest (Standard ist 2 Sekunden).
Lärm, n
Rauschtoleranz einstellen. Kann in dB angegeben werden (falls "dB" an die angegebene . angehängt wird
Wert) oder Amplitudenverhältnis. Der Standardwert ist -60 dB oder 0.001.
Beispiele
· Erkennen Sie 5 Sekunden Stille mit -50dB Rauschtoleranz:
Stilledetect=n=-50dB:d=5
· Komplettes Beispiel mit ffmpeg um Stille mit 0.0001 Rauschtoleranz in . zu erkennen
Stille.mp3:
ffmpeg -i silent.mp3 -af silentdetect=noise=0.0001 -f null -
Stilleentfernen
Entfernen Sie die Stille am Anfang, in der Mitte oder am Ende des Audios.
Der Filter akzeptiert die folgenden Optionen:
start_perioden
Dieser Wert wird verwendet, um anzugeben, ob Audio am Anfang des Audios getrimmt werden soll. EIN
Der Wert Null zeigt an, dass von Anfang an keine Stille getrimmt werden sollte. Wann
Wenn Sie einen Wert ungleich Null angeben, wird das Audio so lange getrimmt, bis keine Stille gefunden wird. Normalerweise,
beim Trimmen der Stille vom Anfang des Audios die start_perioden wird 1 sein, aber es kann
auf höhere Werte erhöht werden, um alle Audiodaten bis zu einer bestimmten Anzahl von Nicht-Stille zu trimmen
Perioden. Der Standardwert ist 0.
start_dauer
Geben Sie an, wie lange keine Stille erkannt werden muss, bevor das Trimmen beendet wird
Audio. Durch Erhöhen der Dauer können Geräuschausbrüche als Stille behandelt werden und
abgeschnitten. Der Standardwert ist 0.
Startschwelle
Dies gibt an, welcher Abtastwert als Stille behandelt werden soll. Für digitales Audio, a
Wert von 0 mag in Ordnung sein, aber für Audio, das von analog aufgenommen wurde, möchten Sie möglicherweise erhöhen
der Wert, um Hintergrundgeräusche zu berücksichtigen. Kann in dB angegeben werden (falls "dB" ist
an den angegebenen Wert angehängt) oder Amplitudenverhältnis. Der Standardwert ist 0.
stop_periods
Legen Sie die Anzahl für das Trimmen der Stille am Ende des Audios fest. Um die Stille aus dem zu entfernen
Mitte einer Datei, spezifizieren Sie a stop_periods das ist negativ. Dieser Wert wird dann behandelt
als positiver Wert und wird verwendet, um anzuzeigen, dass der Effekt die Verarbeitung neu starten sollte, wie
spezifiziert durch start_perioden, wodurch es zum Entfernen von Stilleperioden im
mitten im Audio. Der Standardwert ist 0.
stop_duration
Geben Sie eine Dauer der Stille an, die vorhanden sein muss, bevor Audio nicht mehr kopiert wird. Durch
Bei Angabe einer höheren Dauer kann die gewünschte Stille im Audio gelassen werden.
Der Standardwert ist 0.
stop_threshold
Dies ist das gleiche wie Startschwelle aber zum Trimmen der Stille am Ende des Audios.
Kann in dB (wenn "dB" an den angegebenen Wert angehängt wird) oder Amplitude angegeben werden
Verhältnis. Der Standardwert ist 0.
Leave_silence
Dies weist darauf hin, dass stop_duration Länge des Audios sollte intakt gelassen werden
Beginn jeder Stilleperiode. Wenn Sie beispielsweise lange Pausen entfernen möchten
zwischen Wörtern, möchten aber die Pausen nicht vollständig entfernen. Der Standardwert ist 0.
Beispiele
· Das folgende Beispiel zeigt, wie dieser Filter verwendet werden kann, um eine Aufnahme zu starten, die
enthalten nicht die Verzögerung beim Start, die normalerweise zwischen dem Drücken der Schallplatte auftritt
Taste und Beginn der Aufführung:
Silenceremove=1:5:0.02
Diskant
Erhöhen oder senken Sie die Höhen (obere) Frequenzen des Audios mit einem zweipoligen Shelving-Filter mit
ein Ansprechverhalten ähnlich dem der Klangregler einer Standard-Hi-Fi-Anlage. Dies ist auch bekannt als
Shelving-Entzerrung (EQ).
Der Filter akzeptiert die folgenden Optionen:
gewinnen, g
Geben Sie die Verstärkung bei dem niedrigeren Wert von ~22 kHz und der Nyquist-Frequenz an. Es ist
Der nützliche Bereich liegt zwischen -20 (für einen großen Schnitt) bis +20 (für einen großen Boost). Vorsicht vor
Clipping bei Verwendung einer positiven Verstärkung.
Frequenz, f
Stellen Sie die Mittenfrequenz des Filters ein und können so verwendet werden, um die
Frequenzbereich angehoben oder abgesenkt werden. Der Standardwert ist 3000 Hz.
width_type
Legen Sie die Methode fest, um die Bandbreite des Filters anzugeben.
h Hz
q Q-Faktor
o Oktave
s Hang
Breite, w
Bestimmen Sie, wie steil der Shelf-Übergang des Filters ist.
Volumen
Passen Sie die Audio-Eingangslautstärke an.
Es akzeptiert die folgenden Parameter:
Volumen
Legen Sie den Ausdruck für die Audiolautstärke fest.
Ausgabewerte werden auf den Maximalwert abgeschnitten.
Die Audioausgabelautstärke ergibt sich aus der Beziehung:
= *
Der Standardwert für Volumen ist "1.0".
Präzision
Dieser Parameter repräsentiert die mathematische Genauigkeit.
Es legt fest, welche Eingabe-Sample-Formate zulässig sind, was sich auf die Genauigkeit auswirkt
der Lautstärkeskalierung.
fixiert
8-Bit-Festkomma; dies begrenzt das Eingabe-Sample-Format auf U8, S16 und S32.
schweben
32-Bit-Gleitkomma; dies begrenzt das Eingabe-Sample-Format auf FLT. (Ursprünglich)
doppelt
64-Bit-Gleitkomma; dies begrenzt das Eingabe-Sample-Format auf DBL.
noch einmal spielen
Wählen Sie das Verhalten beim Antreffen von ReplayGain-Seitendaten in Eingabeframes.
fallen lassen
Entfernen Sie ReplayGain-Seitendaten und ignorieren Sie deren Inhalt (Standard).
ignorieren
Ignorieren Sie ReplayGain-Seitendaten, aber lassen Sie sie im Rahmen.
verfolgen sind
Bevorzugen Sie die Spurverstärkung, falls vorhanden.
Album
Bevorzugen Sie die Albumverstärkung, falls vorhanden.
replaygain_preamp
Vorverstärkungsverstärkung in dB, die auf die ausgewählte Replaygain-Verstärkung angewendet wird.
Standardwert für replaygain_preamp ist 0.0.
eval
Wird gesetzt, wenn der Volumenausdruck ausgewertet wird.
Es akzeptiert die folgenden Werte:
einmal
Ausdruck nur einmal während der Filterinitialisierung auswerten, oder wenn die Volumen
Befehl wird gesendet
Rahmen
evaluiere den Ausdruck für jeden eingehenden Frame
Standardwert ist einmal.
Der Volumenausdruck kann die folgenden Parameter enthalten.
n Bildnummer (beginnend bei Null)
nb_channels
Anzahl der Kanäle
nb_consumed_samples
Anzahl der vom Filter verbrauchten Samples
nb_proben
Anzahl der Samples im aktuellen Frame
Post ursprüngliche Frameposition in der Datei
pts Rahmen PTS
Beispielrate
Beispielrate
beginnt
PTS zu Beginn des Streams
starte
Uhrzeit zu Beginn des Streams
t Rahmenzeit
tb Zeitstempel-Zeitbasis
Volumen
zuletzt eingestellter Lautstärkewert
Beachten Sie das wann eval eingestellt ist einmal nur die Beispielrate und tb Variablen sind verfügbar,
alle anderen Variablen werden zu NAN ausgewertet.
Befehle
Dieser Filter unterstützt die folgenden Befehle:
Volumen
Ändern Sie den Volumenausdruck. Der Befehl akzeptiert die gleiche Syntax wie der
entsprechende Option.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
replaygain_noclip
Verhindern Sie Clipping, indem Sie die angewendete Verstärkung begrenzen.
Standardwert für replaygain_noclip ist 1.
Beispiele
· Halbiere die Eingangslautstärke:
Volumen = Volumen = 0.5
Volumen=Volumen=1/2
Lautstärke = Lautstärke = -6.0206 dB
In allen obigen Beispielen ist der benannte Schlüssel für Volumen kann weggelassen werden, zum Beispiel wie in:
Volumen = 0.5
· Erhöhen Sie die Audioeingangsleistung um 6 Dezibel mit Festkomma-Präzision:
Lautstärke=Lautstärke=6dB:Präzision=Fest
· Fade-Lautstärke nach Zeit 10 mit einer Vernichtungszeit von 5 Sekunden:
volume='if(lt(t,10),1,max(1-(t-10)/5,0))':eval=frame
Lautstärke erkennen
Ermitteln Sie die Lautstärke des Eingangsvideos.
Der Filter hat keine Parameter. Die Eingabe wird nicht geändert. Statistiken über das Volumen werden
im Protokoll gedruckt werden, wenn das Ende des Eingabestroms erreicht ist.
Es zeigt insbesondere das mittlere Volumen (root mean square), das maximale Volumen (auf einer
Stichprobenbasis) und den Beginn eines Histogramms der registrierten Volumenwerte (aus dem
Maximalwert auf ein kumuliertes 1/1000 der Stichproben).
Alle Lautstärken sind in Dezibel bezogen auf den maximalen PCM-Wert.
Beispiele
Hier ein Auszug der Ausgabe:
[Parsed_volumedetect_0 0xa23120] mittlere_Lautstärke: -27 dB
[Parsed_volumedetect_0 0xa23120] max_volume: -4 dB
[Parsed_volumedetect_0 0xa23120] histogram_4db: 6
[Parsed_volumedetect_0 0xa23120] histogram_5db: 62
[Parsed_volumedetect_0 0xa23120] histogram_6db: 286
[Parsed_volumedetect_0 0xa23120] histogram_7db: 1042
[Parsed_volumedetect_0 0xa23120] histogram_8db: 2551
[Parsed_volumedetect_0 0xa23120] histogram_9db: 4609
[Parsed_volumedetect_0 0xa23120] histogram_10db: 8409
Es bedeutet, dass:
· Die mittlere quadratische Energie beträgt ungefähr -27 dB oder 10^-2.7.
· Das größte Sample liegt bei -4 dB, genauer gesagt zwischen -4 dB und -5 dB.
· Es gibt 6 Samples bei -4 dB, 62 bei -5 dB, 286 bei -6 dB usw.
Mit anderen Worten, eine Erhöhung der Lautstärke um +4 dB verursacht kein Clipping, eine Erhöhung um +5
dB verursacht Clipping für 6 Samples usw.
AUDIO QUELLEN
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Audioquellen.
ein Puffer
Puffern Sie Audioframes und stellen Sie sie der Filterkette zur Verfügung.
Diese Quelle ist hauptsächlich für eine programmatische Verwendung gedacht, insbesondere durch die Schnittstelle
definiert in libavfilter/asrc_abuffer.h.
Es akzeptiert die folgenden Parameter:
Zeitbasis
Die Zeitbasis, die für Zeitstempel der übermittelten Frames verwendet wird. Es muss entweder sein
eine Gleitkommazahl oder in Zähler/Nenner Form.
Beispielrate
Die Abtastrate der eingehenden Audiopuffer.
sample_fmt
Das Sample-Format der eingehenden Audiopuffer. Entweder ein Beispielformatname oder seine
entsprechende Integer-Darstellung aus der Aufzählung AVSampleFormat in
libavutil/samprefmt.h
Kanal_Layout
Das Kanallayout der eingehenden Audiopuffer. Entweder ein Kanal-Layout-Name von
channel_layout_map ein libavutil/channel_layout.c oder seine entsprechende ganze Zahl
Darstellung aus den AV_CH_LAYOUT_* Makros in libavutil/channel_layout.h
Kanäle
Die Anzahl der Kanäle der eingehenden Audiopuffer. Wenn beides Kanäle und
Kanal_Layout angegeben werden, müssen sie konsistent sein.
Beispiele
abuffer=sample_rate=44100:sample_fmt=s16p:channel_layout=stereo
weist die Quelle an, planares 16-Bit-Stereo mit Vorzeichen bei 44100 Hz zu akzeptieren. Seit der
Sample-Format mit dem Namen "s16p" entspricht der Nummer 6 und dem "Stereo"-Kanal-Layout
entspricht dem Wert 0x3, dies entspricht:
abuffer=sample_rate=44100:sample_fmt=6:channel_layout=0x3
aevalsrc
Generieren Sie ein Audiosignal, das durch einen Ausdruck angegeben wird.
Diese Quelle akzeptiert als Eingabe einen oder mehrere Ausdrücke (einen für jeden Kanal), die
ausgewertet und zur Generierung eines entsprechenden Audiosignals verwendet.
Diese Quelle akzeptiert die folgenden Optionen:
ausdrücken
Legen Sie die durch '|' getrennte Liste der Ausdrücke für jeden einzelnen Kanal fest. Falls die
Kanal_Layout Option nicht angegeben ist, hängt das ausgewählte Kanallayout von der
Anzahl der bereitgestellten Ausdrücke. Andernfalls wird der zuletzt angegebene Ausdruck angewendet auf
die restlichen Ausgangskanäle.
Kanal_Layout, c
Stellen Sie das Kanallayout ein. Die Anzahl der Kanäle im angegebenen Layout muss gleich sein
auf die Anzahl der angegebenen Ausdrücke.
Dauer, d
Legen Sie die Mindestdauer der Audioquelle fest. Sehen Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell für die akzeptierte Syntax. Beachten Sie, dass die resultierende Dauer möglicherweise
länger als die angegebene Dauer sein, da das generierte Audio immer am
Ende eines kompletten Rahmens.
Wenn nicht angegeben oder die angegebene Dauer negativ ist, soll das Audio sein
für immer generiert.
nb_proben, n
Legen Sie die Anzahl der Samples pro Kanal und jedes Ausgabeframe fest, standardmäßig auf 1024.
Beispielrate, s
Geben Sie die Abtastrate an, standardmäßig ist 44100.
Jeder Ausdruck in ausdrücken kann folgende Konstanten enthalten:
n Nummer der ausgewerteten Probe, beginnend bei 0
t Zeit der ausgewerteten Probe in Sekunden, beginnend bei 0
s Beispielrate
Beispiele
· Stille erzeugen:
aevalsrc=0
· Erzeuge ein Sinussignal mit einer Frequenz von 440 Hz, setze die Abtastrate auf 8000 Hz:
aevalsrc="/sin(440*2*PI*t):s=8000"
· Generieren Sie ein Zweikanalsignal, legen Sie das Kanallayout fest (Front Center + Back
Mitte) explizit:
aevalsrc="/sin(420*2*PI*t)|cos(430*2*PI*t):c=FC|BC"
· Weißes Rauschen erzeugen:
aevalsrc="/-2+zufällig(0) "
· Ein amplitudenmoduliertes Signal erzeugen:
aevalsrc="/sin(10*2*PI*t)*sin(880*2*PI*t)"
· Erzeuge binaurale 2.5-Hz-Beats auf einem 360-Hz-Träger:
aevalsrc="/0.1*sin(2*PI*(360-2.5/2)*t) | 0.1*sin(2*PI*(360+2.5/2)*t)"
annullsrc
Die Null-Audioquelle gibt unverarbeitete Audioframes zurück. Es ist hauptsächlich als Vorlage nützlich
und zur Verwendung in Analyse-/Debugging-Tools oder als Quelle für Filter, die
ignorieren Sie die Eingabedaten (zum Beispiel den Sox-Synth-Filter).
Diese Quelle akzeptiert die folgenden Optionen:
Kanal_Layout, cl
Gibt das Kanallayout an und kann entweder eine ganze Zahl oder eine Zeichenfolge sein, die a . darstellt
Kanal-Layout. Der Standardwert von Kanal_Layout ist "Stereo".
Überprüfen Sie die channel_layout_map-Definition in libavutil/channel_layout.c für die Kartierung
zwischen Strings und Kanallayoutwerten.
Beispielrate, r
Gibt die Abtastrate an und ist standardmäßig 44100.
nb_proben, n
Legen Sie die Anzahl der Samples pro angeforderten Frames fest.
Beispiele
· Stellen Sie die Abtastrate auf 48000 Hz und das Kanallayout auf AV_CH_LAYOUT_MONO ein.
anullsrc=r=48000:cl=4
· Führen Sie die gleiche Operation mit einer offensichtlicheren Syntax aus:
anullsrc=r=48000:cl=mono
Alle Parameter müssen explizit definiert werden.
flite
Synthetisieren Sie eine Sprachäußerung mit der libflite-Bibliothek.
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie FFmpeg mit konfigurieren
"--enable-libflite".
Beachten Sie, dass die Flite-Bibliothek nicht threadsicher ist.
Der Filter akzeptiert die folgenden Optionen:
list_voices
Wenn auf 1 gesetzt, listen Sie die Namen der verfügbaren Stimmen auf und beenden Sie sofort. Standard
Wert ist 0.
nb_proben, n
Legen Sie die maximale Anzahl von Samples pro Frame fest. Der Standardwert ist 512.
Textdatei
Legen Sie den Dateinamen fest, der den zu sprechenden Text enthält.
Text
Stellen Sie den Text auf Sprechen ein.
Stimme, v
Stellen Sie die Stimme ein, die für die Sprachsynthese verwendet werden soll. Der Standardwert ist "kal". Siehe auch die
list_voices .
Beispiele
· Aus Datei lesen sprache.txt, und synthetisieren den Text mit der Standard-Flite-Stimme:
flite=textdatei=speech.txt
· Lesen Sie den angegebenen Text, indem Sie die "slt"-Stimme auswählen:
flite=text='Lebe wohl, armer Teufel von einem Sub-Sub, dessen Kommentator ich bin':voice=slt
· Text in ffmpeg eingeben:
ffmpeg -f lavfi -i flite=text='Lebe wohl, armer Teufel von einem Sub-Sub, dessen Kommentator ich bin':voice=slt
· Machen ffplay Sprechen Sie den angegebenen Text mit "flite" und dem "lavfi"-Gerät:
ffplay -f lavfi flite=text='Nicht mehr trauern, was du getan hast.'
Weitere Informationen zu libflite finden Sie unter:http://www.speech.cs.cmu.edu/flite/>
ihre
Generieren Sie ein Audiosignal aus einer Sinuswelle mit einer Amplitude von 1/8.
Das Audiosignal ist bitgenau.
Der Filter akzeptiert die folgenden Optionen:
Frequenz, f
Stellen Sie die Trägerfrequenz ein. Der Standardwert ist 440 Hz.
beep_faktor, b
Aktivieren Sie jede Sekunde einen periodischen Piepton mit der Frequenz beep_faktor mal der träger
Frequenz. Der Standardwert ist 0, was bedeutet, dass der Signalton deaktiviert ist.
Beispielrate, r
Geben Sie die Abtastrate an, der Standardwert ist 44100.
Dauer, d
Geben Sie die Dauer des generierten Audiostreams an.
Samples_per_Frame
Legen Sie die Anzahl der Samples pro Ausgabeframe fest, der Standardwert ist 1024.
Beispiele
· Erzeuge eine einfache 440 Hz Sinuswelle:
ihre
· Erzeuge eine 220-Hz-Sinuswelle mit einem 880-Hz-Piepton pro Sekunde für 5 Sekunden:
Sinus=220:4:d=5
Sinus=f=220:b=4:d=5
Sinus=Frequenz=220:Beep_Faktor=4:Dauer=5
AUDIO SPÜLEN
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Audiosenken.
Puffersink
Puffern Sie Audioframes und stellen Sie sie am Ende der Filterkette zur Verfügung.
Diese Senke ist hauptsächlich für den programmatischen Gebrauch gedacht, insbesondere über die Schnittstelle
definiert in libavfilter/buffersink.h oder das Optionssystem.
Es akzeptiert einen Zeiger auf eine AVABufferSinkContext-Struktur, die den eingehenden . definiert
Pufferformate, die als undurchsichtiger Parameter an "avfilter_init_filter" übergeben werden für
Initialisierung.
annullsink
Null-Audiosenke; tun absolut nichts mit dem Eingangsaudio. Es ist hauptsächlich nützlich als
Vorlage und zur Verwendung in Analyse-/Debugging-Tools.
VIDEO FILTER
Wenn Sie Ihren FFmpeg-Build konfigurieren, können Sie jeden der vorhandenen Filter mit . deaktivieren
"--filter deaktivieren". Die Konfigurationsausgabe zeigt die Videofilter an, die in Ihrem . enthalten sind
bauen.
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Videofilter.
Alphaextrakt
Extrahieren Sie die Alpha-Komponente aus der Eingabe als Graustufenvideo. Das ist besonders praktisch
an. Nach der Installation können Sie HEIC-Dateien mit der Alphamerge Filter.
Alphamerge
Addiere oder ersetze die Alphakomponente der primären Eingabe durch den Graustufenwert von a
zweiter Eingang. Dies ist für die Verwendung mit Alphaextrakt um die Übertragung zu ermöglichen oder
Speicherung von Frame-Sequenzen mit Alpha in einem Format, das Alpha nicht unterstützt
Kanal.
Um beispielsweise Vollbilder aus einem normalen YUV-codierten Video und einem separaten
Video erstellt mit Alphaextrakt, könnten Sie verwenden:
Film=in_alpha.mkv[alpha]; [in][alpha] alphamerge [aus]
Da dieser Filter für die Rekonstruktion ausgelegt ist, arbeitet er mit Frame-Sequenzen ohne
unter Berücksichtigung von Zeitstempeln und endet, wenn eine der Eingaben das Ende des Streams erreicht. Dieser Wille
Probleme verursachen, wenn Ihre Codierungspipeline Frames auslässt. Wenn Sie versuchen, ein Bild anzuwenden
als Overlay zu einem Videostream, betrachten Sie die Auflage stattdessen filtern.
Arsch
Gleich wie die Untertitel filter, außer dass libavcodec und libavformat nicht erforderlich sind, um
arbeiten. Andererseits ist es auf ASS-Untertiteldateien (Advanced Substation Alpha) beschränkt.
Dieser Filter akzeptiert die folgende Option zusätzlich zu den üblichen Optionen aus dem
Untertitel Filter:
Gestaltung
Stellen Sie die Shaping-Engine ein
Verfügbare Werte sind:
Auto
Die Standard-Libass-Shaping-Engine, die die beste verfügbare ist.
einfach
Schneller, schriftunabhängiger Shaper, der nur Ersetzungen durchführen kann
Komplex
Langsamerer Shaper mit OpenType für Ersetzungen und Positionierung
Die Vorgabe ist "automatisch".
Atadenoise
Wenden Sie einen adaptiven zeitlichen Mittelwert-Denoiser auf den Videoeingang an.
Der Filter akzeptiert die folgenden Optionen:
0a Schwellwert A für die 1. Ebene einstellen. Der Standardwert ist 0.02. Gültiger Bereich ist 0 bis 0.3.
0b Schwellwert B für die 1. Ebene einstellen. Der Standardwert ist 0.04. Gültiger Bereich ist 0 bis 5.
1a Schwellwert A für 2. Ebene einstellen. Der Standardwert ist 0.02. Gültiger Bereich ist 0 bis 0.3.
1b Schwellenwert B für 2. Ebene einstellen. Der Standardwert ist 0.04. Gültiger Bereich ist 0 bis 5.
2a Schwellenwert A für 3. Ebene einstellen. Der Standardwert ist 0.02. Gültiger Bereich ist 0 bis 0.3.
2b Schwellenwert B für 3. Ebene einstellen. Der Standardwert ist 0.04. Gültiger Bereich ist 0 bis 5.
Threshold A reagiert auf abrupte Änderungen des Eingangssignals und Threshold B
ist darauf ausgelegt, auf kontinuierliche Änderungen des Eingangssignals zu reagieren.
s Stellen Sie den Filter für die Anzahl der Frames ein, der für die Mittelwertbildung verwendet wird. Der Standardwert ist 33. Muss eine ungerade Zahl sein
im Bereich [5, 129].
bbox
Berechnen Sie den Begrenzungsrahmen für die nicht schwarzen Pixel in der Luminanzebene des Eingabebildes.
Dieser Filter berechnet den Begrenzungsrahmen, der alle Pixel mit einem Luminanzwert enthält
größer als der zulässige Mindestwert. Die Parameter, die die Bounding Box beschreiben, sind
auf dem Filterprotokoll gedruckt.
Der Filter akzeptiert die folgende Option:
min_val
Stellen Sie den minimalen Luminanzwert ein. Standard ist 16.
schwarz erkennen
Erkennen Sie Videointervalle, die (fast) vollständig schwarz sind. Kann nützlich sein, um Kapitel zu erkennen
Übergänge, Werbespots oder ungültige Aufnahmen. Ausgabezeilen enthalten die Zeit für die
Beginn, Ende und Dauer des erkannten Schwarzintervalls, ausgedrückt in Sekunden.
Um die Ausgabezeilen anzuzeigen, müssen Sie den Loglevel mindestens auf den
AV_LOG_INFO-Wert.
Der Filter akzeptiert die folgenden Optionen:
schwarze_min_dauer, d
Stellen Sie die minimale erkannte Schwarzdauer in Sekunden ein. Es muss ein Nicht-
negative Gleitkommazahl.
Der Standardwert ist 2.0.
picture_black_ratio_th, Bild_th
Legen Sie den Schwellenwert fest, um ein Bild als "schwarz" zu betrachten. Drücken Sie den Mindestwert für aus
das Verhältnis:
/
für die ein Bild als schwarz gilt. Der Standardwert ist 0.98.
pixel_schwarz_th, pix_th
Legen Sie den Schwellenwert fest, um ein Pixel als "schwarz" zu betrachten.
Der Schwellenwert drückt den maximalen Pixelluminanzwert aus, für den ein Pixel
gilt als "schwarz". Der bereitgestellte Wert wird nach folgender Gleichung skaliert:
= + *
Luminanzbereich_Größe und luminance_minimum_value hängen vom Eingangsvideoformat ab, die
Bereich ist [0-255] für YUV-Vollbereichsformate und [16-235] für YUV-Nicht-Vollbereich
Formate.
Der Standardwert ist 0.10.
Das folgende Beispiel setzt den maximalen Pixelschwellenwert auf den minimalen Wert und erkennt
nur schwarze Intervalle von 2 oder mehr Sekunden:
blackdetect=d=2:pix_th=0.00
schwarzer Rahmen
Erkennen Sie Frames, die (fast) vollständig schwarz sind. Kann nützlich sein, um Kapitel zu erkennen
Übergänge oder Werbung. Ausgabezeilen bestehen aus der Framenummer des erkannten
Frame, der Schwarzanteil, die Position in der Datei, falls bekannt oder -1 und die
Zeitstempel in Sekunden.
Um die Ausgabezeilen anzuzeigen, müssen Sie den Loglevel mindestens auf den
AV_LOG_INFO-Wert.
Es akzeptiert die folgenden Parameter:
Betrag
Der Prozentsatz der Pixel, die unter dem Schwellenwert liegen müssen; es ist standardmäßig auf 98 eingestellt.
Schwelle, dreschen
Der Schwellenwert, unterhalb dessen ein Pixelwert als schwarz betrachtet wird; es ist standardmäßig 32.
Mischung, tblend
Mischen Sie zwei Videoframes ineinander.
Der Filter "blend" nimmt zwei Input-Streams und gibt einen Stream aus, der erste Input ist der
"obere" Ebene und die zweite Eingabe ist "untere" Ebene. Ausgang endet bei kürzestem Eingang
beendet.
Der Filter "tblend" (Time Blend) nimmt zwei aufeinanderfolgende Frames aus einem einzigen Stream und
gibt das Ergebnis aus, das durch Mischen des neuen Frames über dem alten Frame erhalten wurde.
Eine Beschreibung der akzeptierten Optionen folgt.
c0_mode
c1_mode
c2_mode
c3_mode
all_mode
Legen Sie den Mischmodus für eine bestimmte Pixelkomponente oder alle Pixelkomponenten fest, falls
all_mode. Standardwert ist "normal".
Verfügbare Werte für Komponentenmodi sind:
Zusatz
und
durchschnittlich
brennen
verdunkeln
Unterschied
Unterschied128
aufteilen
Ausweichen
Ausschluss
glühen
hartes Licht
hartmix
aufhellen
lineares Licht
multiplizieren
Negation
normal
or
Auflage
Phönix
Nadellicht
reflektieren
Bildschirm
Sanftes Licht
subtrahieren
Strahlendes Licht
xor
c0_opacity
c1_opacity
c2_opacity
c3_opacity
all_opacity
Legen Sie die Deckkraft der Mischung für eine bestimmte Pixelkomponente oder alle Pixelkomponenten fest, falls
all_opacity. Wird nur in Kombination mit Pixelkomponenten-Mischmodi verwendet.
c0_expr
c1_expr
c2_expr
c3_expr
all_expr
Mischungsausdruck für eine bestimmte Pixelkomponente oder alle Pixelkomponenten festlegen, falls
all_expr. Beachten Sie, dass verwandte Modusoptionen ignoriert werden, wenn diese gesetzt sind.
Die Ausdrücke können die folgenden Variablen verwenden:
N Die fortlaufende Nummer des gefilterten Frames, beginnend bei 0.
X
Y die Koordinaten der aktuellen Probe
W
H die Breite und Höhe der aktuell gefilterten Ebene
SW
SH Breiten- und Höhenskalierung abhängig von der aktuell gefilterten Ebene. Es ist das Verhältnis
zwischen der entsprechenden Anzahl von Pixeln der Luma-Ebene und den Pixeln der aktuellen Ebene.
ZB für YUV4:2:0 sind die Werte "1,1" für die Luma-Ebene und "0.5,0.5" für
Chroma-Ebenen.
T Zeit des aktuellen Frames, ausgedrückt in Sekunden.
OBEN, A
Wert der Pixelkomponente an der aktuellen Position für den ersten Videoframe (obere Ebene).
UNTERSEITE, B
Wert der Pixelkomponente an der aktuellen Position für das zweite Videobild (unten
Schicht).
kürzeste
Beendigung erzwingen, wenn die kürzeste Eingabe beendet wird. Der Standardwert ist 0. Diese Option ist
nur für den Filter "blend" definiert.
wiederholen
Fahren Sie mit dem Anwenden des letzten unteren Frames nach dem Ende des Streams fort. Ein Wert von 0
deaktivieren Sie den Filter, nachdem das letzte Bild der unteren Ebene erreicht wurde. Standard ist 1.
Diese Option ist nur für den Filter "blend" definiert.
Beispiele
· Wenden Sie den Übergang von der unteren Schicht zur oberen Schicht in den ersten 10 Sekunden an:
blend=all_expr='A*(if(gte(T,10),1,T/10))+B*(1-(if(gte(T,10),1,T/10)))'
· 1x1-Schachbrett-Effekt anwenden:
blend=all_expr='if(eq(mod(X,2),mod(Y,2)),A,B)'
· Wenden Sie den linken Effekt aufdecken an:
blend=all_expr='if(gte(N*SW+X,W),A,B)'
· Uncover Down-Effekt anwenden:
blend=all_expr='if(gte(YN*SH,0),A,B)'
· Wenden Sie den Aufdecken-Links-Effekt an:
blend=all_expr='if(gte(T*SH*40+Y,H)*gte((T*40*SW+X)*B/H,W),A,B)'
· Unterschiede zwischen dem aktuellen und dem vorherigen Frame anzeigen:
tblend=all_mode=difference128
Box Unschärfe
Wenden Sie einen Boxblur-Algorithmus auf das Eingabevideo an.
Es akzeptiert die folgenden Parameter:
luma_radius, lr
luma_power, lp
Farbradius, cr
chroma_power, cp
alpha_radius, ar
alpha_power, ap
Eine Beschreibung der akzeptierten Optionen folgt.
luma_radius, lr
Farbradius, cr
alpha_radius, ar
Legen Sie einen Ausdruck für den Boxradius in Pixeln fest, der zum Verwischen der entsprechenden verwendet wird
Eingabeebene.
Der Radiuswert muss eine nicht negative Zahl sein und darf nicht größer sein als der Wert
des Ausdrucks "min(w,h)/2" für die Luma- und Alpha-Ebene und von "min(cw,ch)/2"
für die Chroma-Ebenen.
Standardwert für luma_radius ist "2". Wenn nicht angegeben, chroma_radius und alpha_radius
Standardwert auf den entsprechenden Wert eingestellt für luma_radius.
Die Ausdrücke können die folgenden Konstanten enthalten:
w
h Die Eingabebreite und -höhe in Pixeln.
cw
ch Die Breite und Höhe des eingegebenen Chroma-Bildes in Pixeln.
hsub
vssub
Die horizontalen und vertikalen Chroma-Subsample-Werte. Zum Beispiel für das Pixel
Format "yuv422p", hsub ist 2 und vssub ist 1.
luma_power, lp
chroma_power, cp
alpha_power, ap
Geben Sie an, wie oft der Boxblur-Filter auf die entsprechende Ebene angewendet wird.
Standardwert für luma_power ist 2. Wenn nicht angegeben, chroma_power und alpha_power
Standardwert auf den entsprechenden Wert eingestellt für luma_power.
Ein Wert von 0 deaktiviert den Effekt.
Beispiele
· Wenden Sie einen Boxblur-Filter an, wobei Luma, Chroma und Alpha-Radien auf 2 eingestellt sind:
boxblur=luma_radius=2:luma_power=1
Boxunschärfe=2:1
· Stellen Sie den Luma-Radius auf 2 und den Alpha- und Chroma-Radius auf 0:
boxblur=2:1:cr=0:ar=0
· Stellen Sie Luma- und Chroma-Radien auf einen Bruchteil der Videodimension ein:
boxblur=luma_radius=min(h\,w)/10:luma_power=1:chroma_radius=min(cw\,ch)/10:chroma_power=1
Codecansicht
Visualisieren Sie Informationen, die von einigen Codecs exportiert wurden.
Einige Codecs können Informationen mithilfe von Seitendaten oder auf andere Weise durch Frames exportieren. Für
Einige MPEG-basierte Codecs exportieren beispielsweise Bewegungsvektoren über die export_mvs Flagge in der
Codec flags2 .
Der Filter akzeptiert die folgende Option:
mv Stellen Sie Bewegungsvektoren zur Visualisierung ein.
Verfügbare Flaggen für mv sind:
pf vorwärts vorhergesagte MVs von P-Frames
bf vorwärts vorhergesagte MVs von B-Frames
bb rückwärts vorhergesagte MVs von B-Frames
Beispiele
· Visualisiert multidirektionale MVs von P- und B-Frames mit ffplay:
ffplay -flags2 +export_mvs input.mpg -vf codecview=mv=pf+bf+bb
Farbbalance
Ändern Sie die Intensität der Primärfarben (Rot, Grün und Blau) von Eingabebildern.
Mit dem Filter kann ein Eingabebild in den Schatten, Mitteltönen oder Lichtern angepasst werden
Regionen für die Rot-Cyan-, Grün-Magenta- oder Blau-Gelb-Balance.
Ein positiver Anpassungswert verschiebt die Balance in Richtung der Primärfarbe, ein negativer Wert
in Richtung der Komplementärfarbe.
Der Filter akzeptiert die folgenden Optionen:
rs
gs
bs Passen Sie rote, grüne und blaue Schatten (dunkelste Pixel) an.
rm
gm
bm Passen Sie rote, grüne und blaue Mitteltöne (mittlere Pixel) an.
rh
gh
bh Passen Sie rote, grüne und blaue Highlights (hellste Pixel) an.
Zulässige Bereiche für Optionen sind "[-1.0, 1.0]". Standardwerte sind 0.
Beispiele
· Fügen Sie den Schatten einen roten Farbstich hinzu:
Farbbalance=rs=.3
Farbschlüssel
Farbkeying im RGB-Farbraum.
Der Filter akzeptiert die folgenden Optionen:
Farbe
Die Farbe, die durch Transparenz ersetzt wird.
Ähnlichkeit
Ähnlichkeitsprozentsatz mit der Schlüsselfarbe.
0.01 stimmt nur mit der genauen Tastenfarbe überein, während 1.0 mit allem übereinstimmt.
mischen
Mischungsprozentsatz.
0.0 macht Pixel entweder vollständig transparent oder gar nicht transparent.
Höhere Werte ergeben halbtransparente Pixel, bei höherer Transparenz umso mehr
ähnlich ist die Pixelfarbe der Schlüsselfarbe.
Beispiele
· Machen Sie jedes grüne Pixel im Eingabebild transparent:
ffmpeg -i input.png -vf colorkey=green out.png
· Überlagern Sie ein Greenscreen-Video über ein statisches Hintergrundbild.
ffmpeg -i background.png -i video.mp4 -filter_complex "[1:v]colorkey=0x3BBD1E:0.3:0.2[ckout];[0:v][ckout]overlay[out]" -map "[out]" ausgabe.flv
Farbstufen
Passen Sie die Videoeingangsbilder mithilfe von Pegeln an.
Der Filter akzeptiert die folgenden Optionen:
Rimin
gimin
zweimin
zielen
Passen Sie den Rot-, Grün-, Blau- und Alpha-Input-Schwarzpunkt an. Zulässige Bereiche für Optionen sind
"[-1.0, 1.0]". Standardwerte sind 0.
Rimax
Gimax
Bimax
Aimax
Passen Sie den Rot-, Grün-, Blau- und Alpha-Eingangsweißpunkt an. Zulässige Bereiche für Optionen sind
"[-1.0, 1.0]". Standardwerte sind 1.
Eingangspegel werden verwendet, um Lichter (helle Töne) aufzuhellen, Schatten (dunkel) abzudunkeln
Töne), ändern Sie die Balance zwischen hellen und dunklen Tönen.
Romin
gomin
geboren
ömin
Passen Sie den Rot-, Grün-, Blau- und Alpha-Ausgabe-Schwarzpunkt an. Zulässige Bereiche für Optionen sind
"[0, 1.0]". Standardwerte sind 0.
Romantik
gomax
bomax
Aomax
Passen Sie den Rot-, Grün-, Blau- und Alpha-Ausgangsweißpunkt an. Zulässige Bereiche für Optionen sind
"[0, 1.0]". Standardwerte sind 1.
Ausgangspegel ermöglicht die manuelle Auswahl eines eingeschränkten Ausgangspegelbereichs.
Beispiele
· Videoausgabe dunkler machen:
Farbstufen=rimin=0.058:gimin=0.058:bimin=0.058
· Kontrast erhöhen:
colorlevels=rimin=0.039:gimin=0.039:bimin=0.039:rimax=0.96:gimax=0.96:bimax=0.96
· Videoausgabe heller machen:
Farbstufen=rimax=0.902:gimax=0.902:bimax=0.902
· Helligkeit erhöhen:
Farbstufen=romin=0.5:gomin=0.5:bomin=0.5
Farbkanalmischer
Passen Sie die Videoeingangsbilder an, indem Sie die Farbkanäle neu mischen.
Dieser Filter modifiziert einen Farbkanal, indem er die Werte hinzufügt, die den anderen Kanälen zugeordnet sind
der gleichen Pixel. Wenn der zu ändernde Wert beispielsweise rot ist, lautet der Ausgabewert:
= * + * + * + *
Der Filter akzeptiert die folgenden Optionen:
rr
rg
rb
ra Passen Sie den Beitrag der Rot-, Grün-, Blau- und Alphakanäle für die Ausgabe Rot an
Kanal. Standard ist 1 für rrund 0 für rg, rb und ra.
gr
gg
gb
ga Passen Sie den Beitrag der roten, grünen, blauen und Alpha-Eingangskanäle für den grünen Ausgang an
Kanal. Standard ist 1 für ggund 0 für gr, gb und ga.
br
bg
bb
ba Passen Sie den Beitrag der roten, grünen, blauen und Alpha-Eingangskanäle für den blauen Ausgang an
Kanal. Standard ist 1 für bbund 0 für br, bg und ba.
ar
ag
ab
aa Passen Sie den Beitrag der roten, grünen, blauen und Alpha-Eingangskanäle für den Alpha-Ausgang an
Kanal. Standard ist 1 für aaund 0 für ar, ag und ab.
Zulässige Bereiche für Optionen sind "[-2.0, 2.0]".
Beispiele
· Quelle in Graustufen umwandeln:
colorchannelmixer=.3:.4:.3:0:.3:.4:.3:0:.3:.4:.3
· Sepia-Töne simulieren:
colorchannelmixer=.393:.769:.189:0:.349:.686:.168:0:.272:.534:.131
Farbmatrix
Farbmatrix konvertieren.
Der Filter akzeptiert die folgenden Optionen:
src
dst Geben Sie die Quell- und Zielfarbmatrix an. Beide Werte müssen angegeben werden.
Die akzeptierten Werte sind:
bt709
BT.709
bt601
BT.601
smpte240m
SMPTE-240M
Fcc FCC
Um beispielsweise von BT.601 in SMPTE-240M zu konvertieren, verwenden Sie den Befehl:
colormatrix=bt601:smpte240m
Kopieren
Kopieren Sie die Eingangsquelle unverändert in die Ausgabe. Dies ist hauptsächlich für Testzwecke nützlich.
Ernte
Beschneiden Sie das Eingabevideo auf die angegebenen Abmessungen.
Es akzeptiert die folgenden Parameter:
w, aus_w
Die Breite des Ausgabevideos. Der Standardwert ist "iw". Dieser Ausdruck wird nur ausgewertet
einmal während der Filterkonfiguration oder wenn die w or aus_w Befehl wird gesendet.
h, aus_h
Die Höhe des Ausgabevideos. Der Standardwert ist "ih". Dieser Ausdruck wird ausgewertet
nur einmal während der Filterkonfiguration, oder wenn die h or aus_h Befehl wird gesendet.
x Die horizontale Position des linken Rands des Ausgabevideos im Eingabevideo. Es
ist standardmäßig "(in_w-out_w)/2". Dieser Ausdruck wird pro Frame ausgewertet.
y Die vertikale Position des oberen Rands des Ausgabevideos im Eingabevideo. Es
ist standardmäßig "(in_h-out_h)/2". Dieser Ausdruck wird pro Frame ausgewertet.
keep_aspekt
Wenn es auf 1 gesetzt ist, wird das Seitenverhältnis der Ausgabeanzeige mit dem der Eingabe erzwungen, um
Ändern des Seitenverhältnisses der Ausgabeprobe. Es ist standardmäßig 0.
Die aus_w, aus_h, x, y Parameter sind Ausdrücke, die die folgenden Konstanten enthalten:
x
y Die berechneten Werte für x und y. Sie werden für jeden neuen Frame ausgewertet.
in_w
in_h
Die Eingabebreite und -höhe.
iw
ih Das sind die gleichen wie in_w und in_h.
aus_w
aus_h
Die Breite und Höhe der Ausgabe (beschnitten).
ow
oh Das sind die gleichen wie aus_w und aus_h.
a wie iw / ih
sar Seitenverhältnis des Eingabebeispiels
geben das Seitenverhältnis der Eingabeanzeige ist dasselbe wie (iw / ih) * sar
hsub
vssub
horizontale und vertikale Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
n Die Nummer des Eingabeframes, beginnend bei 0.
Post die Position in der Datei des Eingabeframes, NAN falls unbekannt
t Der in Sekunden ausgedrückte Zeitstempel. Es ist NAN, wenn der Eingabezeitstempel unbekannt ist.
Der Ausdruck für aus_w kann vom Wert von abhängen aus_h, und der Ausdruck für aus_h
kann davon abhängen aus_w, aber darauf können sie sich nicht verlassen x und y, wie x und y werden ausgewertet nach
aus_w und aus_h.
Die x und y Parameter spezifizieren die Ausdrücke für die Position der oberen linken Ecke von
der Ausgabebereich (nicht beschnitten). Sie werden für jeden Frame ausgewertet. Wenn der ausgewertete Wert
ungültig ist, wird er dem nächsten gültigen Wert angenähert.
Der Ausdruck für x kann davon abhängen y, und der Ausdruck für y kann davon abhängen x.
Beispiele
· Beschneidungsbereich mit der Größe 100x100 an Position (12,34).
Zuschneiden=100:100:12:34
Mit benannten Optionen wird das obige Beispiel zu:
Zuschneiden=w=100:h=100:x=12:y=34
· Beschneiden Sie den zentralen Eingabebereich mit der Größe 100x100:
Zuschneiden=100:100
· Beschneiden Sie den zentralen Eingabebereich mit der Größe 2/3 des Eingabevideos:
Zuschneiden=2/3*in_w:2/3*in_h
· Beschneiden Sie das zentrale Quadrat des Eingangsvideos:
Crop=out_w=in_h
Crop=in_h
· Begrenzen Sie das Rechteck mit der oberen linken Ecke an Position 100:100 und dem
rechte untere Ecke, die der rechten unteren Ecke des Eingabebildes entspricht.
Crop=in_w-100:in_h-100:100:100
· Beschneiden Sie 10 Pixel vom linken und rechten Rand und 20 Pixel vom oberen und unteren Rand
Grenzen
Crop=in_w-2*10:in_h-2*20
· Behalten Sie nur das untere rechte Viertel des Eingabebilds bei:
Crop=in_w/2:in_h/2:in_w/2:in_h/2
· Erntehöhe für griechische Harmonie:
Crop=in_w:1/PHI*in_w
· Zittereffekt anwenden:
crop=in_w/2:in_h/2:(in_w-out_w)/2+((in_w-out_w)/2)*sin(n/10):(in_h-out_h)/2 +((in_h-out_h)/2)*sin(n/7)
· Wenden Sie je nach Zeitstempel einen unregelmäßigen Kameraeffekt an:
crop=in_w/2:in_h/2:(in_w-out_w)/2+((in_w-out_w)/2)*sin(t*10):(in_h-out_h)/2 +((in_h-out_h)/2)*sin(t*13)"
· Setzen Sie x abhängig vom Wert von y:
crop=in_w/2:in_h/2:y:10+10*sin(n/10)
Befehle
Dieser Filter unterstützt die folgenden Befehle:
w, aus_w
h, aus_h
x
y Breite/Höhe des Ausgabevideos und die horizontale/vertikale Position im Eingang einstellen
Video. Der Befehl akzeptiert dieselbe Syntax wie die entsprechende Option.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
Zuschneiden
Automatische Erkennung der Zuschneidegröße.
Es berechnet die notwendigen Zuschneideparameter und druckt die empfohlenen Parameter über
das Logging-System. Die erkannten Abmessungen entsprechen dem nicht schwarzen Bereich der Eingabe
Video.
Es akzeptiert die folgenden Parameter:
begrenzen
Stellen Sie einen höheren Schwarzwert-Schwellenwert ein, der optional von Null angegeben werden kann (0)
zu allem (255 für 8bit-basierte Formate). Ein Intensitätswert größer als der eingestellte
Wert wird als nicht schwarz betrachtet. Der Standardwert ist 24. Sie können auch einen Wert angeben
zwischen 0.0 und 1.0, die je nach Bittiefe des Pixels skaliert werden
Format.
rund
Der Wert, durch den die Breite/Höhe teilbar sein soll. Der Standardwert ist 16. Der Offset
wird automatisch angepasst, um das Video zu zentrieren. Verwenden Sie 2, um nur gerade Abmessungen zu erhalten
(wird für 4:2:2-Video benötigt). 16 ist am besten für die Codierung in die meisten Videocodecs geeignet.
reset_count, zurückstellen
Stellen Sie den Zähler ein, der bestimmt, nach wie vielen Frames cropdetect den
zuvor erkannten größten Videobereich und beginnen Sie erneut, um das aktuelle Optimum zu erkennen
Erntebereich. Der Standardwert ist 0.
Dies kann nützlich sein, wenn Kanallogos den Videobereich verzerren. 0 bedeutet „nie“
reset' und gibt den größten Bereich zurück, der während der Wiedergabe angetroffen wurde.
Kurven
Wenden Sie Farbanpassungen mithilfe von Kurven an.
Dieser Filter ähnelt den Kurvenwerkzeugen von Adobe Photoshop und GIMP. Jede Komponente (rot,
grün und blau) hat seine Werte definiert durch N Schlüsselpunkte mit einem glatten
Kurve. Die x-Achse repräsentiert die Pixelwerte aus dem Eingabeframe und die y-Achse die neuen
Pixelwerte, die für den Ausgaberahmen eingestellt werden sollen.
Standardmäßig wird eine Komponentenkurve durch die beiden Punkte definiert (0;0) und (1;1). Dies schafft eine
gerade Linie, bei der jeder ursprüngliche Pixelwert auf seinen eigenen Wert "angepasst" wird, was bedeutet
keine Änderung am Bild.
Mit dem Filter können Sie diese beiden Punkte neu definieren und weitere hinzufügen. Eine neue Kurve (mit a
natürliche kubische Spline-Interpolation) werden so definiert, dass sie alle diese neuen
Koordinaten. Die neu definierten Punkte müssen über der x-Achse streng ansteigend sein, und
ihr x und y Werte müssen in der [0;1] Intervall. Wenn die berechneten Kurven zufällig gehen
außerhalb der Vektorräume werden die Werte entsprechend abgeschnitten.
Wenn in "x=0" kein Schlüsselpunkt definiert ist, fügt der Filter automatisch a . ein (0;0)
Punkt. Auf die gleiche Weise wird der Filter, wenn in "x=1" kein Schlüsselpunkt definiert ist,
automatisch einfügen a (1;1) Punkt.
Der Filter akzeptiert die folgenden Optionen:
voreingestellten
Wählen Sie eine der verfügbaren Farbvoreinstellungen aus. Diese Option kann zusätzlich zum
r, g, b Parameter; in diesem Fall haben die späteren Optionen Vorrang vor der Voreinstellung
Werte. Verfügbare Voreinstellungen sind:
keine
color_negativ
Kreuzprozess
dunkler
Kontrast erhöhen
Feuerzeug
linearer_kontrast
mittlerer_kontrast
Negativ
starker_kontrast
Jahrgang
Standard ist "keine".
Meister, m
Legen Sie die Hauptschlüsselpunkte fest. Diese Punkte definieren ein zweites Durchlauf-Mapping. es ist
manchmal auch als "Luminanz"- oder "Wert"-Zuordnung bezeichnet. Es kann verwendet werden mit r, g, b or alle
da es sich wie eine Nachbearbeitungs-LUT verhält.
roten r
Legen Sie die Eckpunkte für die rote Komponente fest.
grün g
Legen Sie die Eckpunkte für die grüne Komponente fest.
blau, b
Legen Sie die Eckpunkte für die blaue Komponente fest.
alle Legen Sie die Eckpunkte für alle Komponenten (außer Master) fest. Kann zusätzlich verwendet werden
zu den anderen Schlüsselpunkten Komponentenoptionen. In diesem Fall wird die nicht gesetzte(n) Komponente(n)
darauf zurückgreifen alle Einstellung.
ps-Datei
Geben Sie eine Photoshop-Kurvendatei (".asv") an, aus der die Einstellungen importiert werden sollen.
Um einige Konflikte in der Filtergraph-Syntax zu vermeiden, muss jede Schlüsselpunktliste mit . definiert werden
folgende Syntax: "x0/y0 x1/y1 x2/y2 ...".
Beispiele
· Erhöhen Sie leicht die mittlere Blaustufe:
Kurven=blau='0.5/0.58'
· Vintage-Effekt:
curves=r='0/0.11 .42/.51 1/0.95':g='0.50/0.48':b='0/0.22 .49/.44 1/0.8'
Hier erhalten wir für jede Komponente die folgenden Koordinaten:
roten "(0;0.11) (0.42;0.51) (1;0.95)"
grünen
"(0;0) (0.50;0.48) (1;1)"
blau
"(0;0.22) (0.49;0.44) (1;0.80)"
· Das vorherige Beispiel lässt sich auch mit dem dazugehörigen eingebauten Preset erreichen:
Kurven=Voreinstellung=Vintage
· Oder einfach:
Kurven = Vintage
· Verwenden Sie eine Photoshop-Vorgabe und definieren Sie die Punkte der Grünkomponente neu:
curves=psfile='MyCurvesPresets/purple.asv':green='0.45/0.53'
dctdnoiz
Entrauschen Sie Frames mit 2D DCT (Frequency Domain Filtering).
Dieser Filter ist nicht für Echtzeit ausgelegt.
Der Filter akzeptiert die folgenden Optionen:
Sigma, s
Stellen Sie die Rausch-Sigma-Konstante ein.
Dieses Sigma definiert einen harten Schwellenwert von "3 * Sigma"; jeder DCT-Koeffizient (absolut
Wert) unterhalb dieser Schwelle fallengelassen werden.
Wenn Sie eine erweiterte Filterung benötigen, lesen Sie ausdr.
Standard ist 0.
überlappen
Legen Sie die Anzahl überlappender Pixel für jeden Block fest. Da der Filter langsam sein kann, können Sie
diesen Wert reduzieren möchten, auf Kosten eines weniger effektiven Filters und der Gefahr von
verschiedene Artefakte.
Wenn der überlappende Wert nicht die Verarbeitung der gesamten Eingabebreite oder -höhe zulässt, a
Warnung wird angezeigt und entsprechende Grenzen werden nicht entrauscht.
Standardwert ist Block Größe-1, was die bestmögliche Einstellung ist.
Ausdruck, e
Stellen Sie den Koeffizientenfaktor-Ausdruck ein.
Für jeden Koeffizienten eines DCT-Blocks wird dieser Ausdruck als Multiplikator ausgewertet
Wert für den Koeffizienten.
Wenn diese Option aktiviert ist, wird die Sigma Option wird ignoriert.
Der Absolutwert des Koeffizienten kann über die c variabel.
n Setze die Block Größe die Anzahl der Bits verwenden. "1<n" definiert die Block Größe, das ist die
Breite und Höhe der bearbeiteten Blöcke.
Der Standardwert ist 3 (8x8) und kann erhöht werden auf 4 für eine Block Größe von 16x16. Notiz
dass das Ändern dieser Einstellung enorme Auswirkungen auf die Verarbeitungsgeschwindigkeit hat. Auch eine
größere Blockgröße bedeutet nicht unbedingt eine bessere Rauschunterdrückung.
Beispiele
Anwenden einer Entrauschung mit a Sigma von 4.5:
dctdnoiz=4.5
Die gleiche Operation kann mit dem Expressionssystem erreicht werden:
dctdnoiz=e='gte(c, 4.5*3)'
Heftige Rauschunterdrückung mit einer Blockgröße von "16x16":
dctdnoiz=15:n=4
auflösen
Entfernen Sie Banding-Artefakte aus dem Eingangsvideo. Es funktioniert, indem es gebänderte Pixel durch ersetzt
Durchschnittswert der referenzierten Pixel.
Der Filter akzeptiert die folgenden Optionen:
1
2
3
4
Legen Sie den Schwellenwert für die Banding-Erkennung für jede Ebene fest. Der Standardwert ist 0.02. Gültiger Bereich ist
0.00003 bis 0.5. Wenn die Differenz zwischen aktuellem Pixel und Referenzpixel kleiner ist als
Schwelle, wird sie als gebändert betrachtet.
Angebot, r
Banding-Erkennungsbereich in Pixeln. Der Standardwert ist 16. Wenn positiv, Zufallszahl im Bereich
0 bis Einstellwert wird verwendet. Bei negativem Wert wird der exakte Absolutwert verwendet. Der
range definiert ein Quadrat von vier Pixeln um das aktuelle Pixel herum.
Richtung, d
Legen Sie die Richtung im Bogenmaß fest, ab der vier Pixel verglichen werden. Wenn positiv, zufällig
Richtung von 0 bis zur eingestellten Richtung wird ausgewählt. Falls negativ, exakt vom absoluten Wert
wird abgeholt. Zum Beispiel werden in Richtung 0, -PI oder -2*PI Bogenmaß nur Pixel ausgewählt
gleiche Zeile und -PI/2 werden nur Pixel in derselben Spalte auswählen.
verwischen
Wenn aktiviert, wird das aktuelle Pixel mit dem Durchschnittswert aller vier umgebenden Pixel verglichen
Pixel. Die Standardeinstellung ist aktiviert. Wenn deaktiviert, wird das aktuelle Pixel mit allen vier verglichen
umgebende Pixel. Das Pixel gilt als gebändert, wenn nur alle vier Unterschiede mit
umgebende Pixel sind kleiner als der Schwellenwert.
dezimieren
Lassen Sie doppelte Frames in regelmäßigen Abständen fallen.
Der Filter akzeptiert die folgenden Optionen:
Zyklus
Legen Sie die Anzahl der Frames fest, von denen einer gelöscht wird. Einstellen auf N bedeutet eins
Rahmen in jeder Charge von N Frames werden ausgelassen. Standard ist 5.
duptresh
Legen Sie den Schwellenwert für die Duplikaterkennung fest. Wenn die Differenzmetrik für einen Frame ist
kleiner oder gleich diesem Wert, dann wird es als Duplikat deklariert. Standard ist 1.1
scthresh
Stellen Sie den Schwellenwert für den Szenenwechsel ein. Standard ist 15.
blockx
blocky
Legen Sie die Größe der X- und Y-Achsenblöcke fest, die bei metrischen Berechnungen verwendet werden. Größer
Blöcke bieten eine bessere Rauschunterdrückung, aber auch eine schlechtere Erkennung von kleinen
Bewegungen. Muss eine Zweierpotenz sein. Der Standardwert ist 32.
ppsrc
Markieren Sie die Haupteingabe als vorverarbeitete Eingabe und aktivieren Sie den sauberen Quelleingabestrom. Dies
ermöglicht die Vorverarbeitung der Eingabe mit verschiedenen Filtern, um die Metriken zu unterstützen
Berechnung, während die Frame-Auswahl verlustfrei bleibt. Wenn auf 1 gesetzt, wird der erste
stream ist für die vorverarbeitete Eingabe und der zweite Stream ist die saubere Quelle von
wo die beibehaltenen Frames ausgewählt werden. Standard ist 0.
Chroma
Legen Sie fest, ob die Farbsättigung bei den metrischen Berechnungen berücksichtigt wird oder nicht. Standard ist 1.
deflate
Wenden Sie den Deflate-Effekt auf das Video an.
Dieser Filter ersetzt das Pixel durch das aus einer regionalen(3x3) Durchschnitt nur unter Berücksichtigung
Werte niedriger als das Pixel.
Es akzeptiert die folgenden Optionen:
Schwelle0
Schwelle1
Schwelle2
Schwelle3
Begrenzen Sie die maximale Änderung für jede Ebene, der Standardwert ist 65535. Bei 0 bleibt die Ebene bestehen
unverändert.
entrümpeln
Entfernen Sie Ruckeln, die durch teilweise interlaced telecined Inhalt erzeugt werden.
Judder kann zum Beispiel eingeführt werden durch Pullup Filter. Wenn die Originalquelle
teilweise telecined Inhalt dann hat die Ausgabe von "pullup,dejudder" eine Variable
Bildrate. Kann die aufgezeichnete Framerate des Containers ändern. Abgesehen von dieser Änderung,
Dieser Filter wirkt sich nicht auf Videos mit konstanter Bildrate aus.
Die in diesem Filter verfügbare Option ist:
Zyklus
Geben Sie die Länge des Fensters an, über das sich das Ruckeln wiederholt.
Akzeptiert jede ganze Zahl größer als 1. Nützliche Werte sind:
4 Wenn das Original von 24 bis 30 fps telecined wurde (Film auf NTSC).
5 Wenn das Original von 25 bis 30 fps (PAL zu NTSC) telecined wurde.
20 Wenn eine Mischung aus beidem.
Die Standardeinstellung ist 4.
Delogo
Unterdrücken Sie ein TV-Sender-Logo durch eine einfache Interpolation der umgebenden Pixel. Stellen Sie einfach ein
Rechteck, das das Logo bedeckt, und sieh zu, wie es verschwindet (und manchmal etwas noch Hässlicheres)
erscheinen - Ihr Kilometerstand kann variieren).
Es akzeptiert die folgenden Parameter:
x
y Geben Sie die Koordinaten der oberen linken Ecke des Logos an. Sie müssen angegeben werden.
w
h Geben Sie die Breite und Höhe des zu löschenden Logos an. Sie müssen angegeben werden.
Band, t
Geben Sie die Dicke der unscharfen Kante des Rechtecks an (hinzugefügt zu w und h). Die
Standardwert ist 4.
erklären
Bei der Einstellung 1 wird auf dem Bildschirm ein grünes Rechteck gezeichnet, um das Auffinden des richtigen zu vereinfachen
x, y, w und h Parameter. Der Standardwert ist 0.
Das Rechteck wird auf den äußersten Pixeln gezeichnet, die (teilweise) ersetzt werden durch
interpolierte Werte. Die Werte der nächsten Pixel unmittelbar außerhalb dieses Rechtecks
in jede Richtung werden verwendet, um die interpolierten Pixelwerte innerhalb des zu berechnen
Rechteck.
Beispiele
· Legen Sie ein Rechteck fest, das den Bereich mit den Koordinaten der oberen linken Ecke 0,0 und der Größe abdeckt
100x77 und ein Band der Größe 10:
delogo=x=0:y=0:w=100:h=77:band=10
abschütteln
Versuchen Sie, kleine Änderungen der horizontalen und/oder vertikalen Verschiebung zu korrigieren. Dieser Filter hilft beim Entfernen
Verwackeln der Kamera durch das Halten einer Kamera in der Hand, das Anstoßen eines Stativs, das Bewegen auf einem Fahrzeug usw.
Der Filter akzeptiert die folgenden Optionen:
x
y
w
h Geben Sie einen rechteckigen Bereich an, in dem die Suche nach Bewegungsvektoren eingeschränkt werden soll. Wenn gewünscht
die Suche nach Bewegungsvektoren kann auf einen rechteckigen Bereich des Bildes beschränkt werden
definiert durch seine obere linke Ecke, Breite und Höhe. Diese Parameter haben das gleiche
Bedeutung als Drawbox-Filter, mit dem die Position des
Begrenzungsrahmen.
Dies ist nützlich, wenn die gleichzeitige Bewegung von Objekten innerhalb des Rahmens
durch die Bewegungsvektorsuche für Kamerabewegungen verwechselt.
Wenn einige oder alle von x, y, w und h auf -1 gesetzt sind, wird das Vollbild verwendet. Dies erlaubt
spätere Optionen, die ohne Angabe des Begrenzungsrahmens für den Bewegungsvektor gesetzt werden sollen
Suche.
Standard - den gesamten Frame durchsuchen.
rx
ry Geben Sie das maximale Ausmaß der Bewegung in x- und y-Richtung im Bereich von 0-64 Pixel an.
Vorgabe 16.
Rand
Geben Sie an, wie Pixel generiert werden, um Leerstellen am Rand des Rahmens zu füllen. Erhältlich
Werte sind:
leer, 0
Füllen Sie Nullen an leeren Stellen
original, 1
Originalbild an leeren Stellen
Klemme, 2
Extrudierter Kantenwert an leeren Stellen
Spiegel, 3
Gespiegelte Kante an leeren Stellen
Standardwert ist Spiegel.
Block Größe
Geben Sie die Blockgröße an, die für die Bewegungssuche verwendet werden soll. Bereich 4-128 Pixel, Standardwert 8.
Kontrast
Legen Sie die Kontrastschwelle für Blöcke fest. Nur Blöcke mit mehr als den angegebenen
Kontrast (Unterschied zwischen dunkelsten und hellsten Pixeln) wird berücksichtigt. Bereich
1-255, Standard 125.
search
Geben Sie die Suchstrategie an. Verfügbare Werte sind:
erschöpfend, 0
Erschöpfende Suche einstellen
Weniger, 1
Stellen Sie eine weniger umfassende Suche ein.
Standardwert ist umfassend.
Dateinamen
Wenn gesetzt, wird ein detailliertes Protokoll der Bewegungssuche in die angegebene Datei geschrieben.
OpenCL
Wenn auf 1 gesetzt, geben Sie die Verwendung von OpenCL-Fähigkeiten an, nur verfügbar, wenn FFmpeg war
mit "--enable-opencl" konfiguriert. Der Standardwert ist 0.
detelecin
Wenden Sie eine genaue Umkehrung der Telecine-Operation an. Es erfordert ein vordefiniertes Muster
mit der Option pattern angegeben, die mit der an das Telecine übergebenen identisch sein muss
Filter.
Dieser Filter akzeptiert die folgenden Optionen:
erstes_feld
oben, t
oberstes Feld zuerst
Unterseite, b
unteres Feld zuerst Der Standardwert ist "top".
Anleitungen
Eine Zahlenfolge, die das Pulldown-Muster darstellt, das Sie anwenden möchten. Der Standard
Wert ist 23.
start_frame
Eine Zahl, die die Position des ersten Frames in Bezug auf den Telecine darstellt
Muster. Dies ist zu verwenden, wenn der Stream unterbrochen wird. Der Standardwert ist 0.
Erweiterung
Wenden Sie den Dilatationseffekt auf das Video an.
Dieser Filter ersetzt das Pixel durch das aus einer regionalen(3x3) maximal.
Es akzeptiert die folgenden Optionen:
Schwelle0
Schwelle1
Schwelle2
Schwelle3
Begrenzen Sie die maximale Änderung für jede Ebene, der Standardwert ist 65535. Bei 0 bleibt die Ebene bestehen
unverändert.
Koordinaten
Flag, das das Pixel angibt, auf das verwiesen werden soll. Der Standardwert ist 255, dh alle acht Pixel sind
benutzt.
Flaggen zu lokalen 3x3-Koordinatenkarten wie folgt:
1 2 3
4 5
6 7 8
Ziehkiste
Zeichnen Sie einen farbigen Kasten auf das Eingabebild.
Es akzeptiert die folgenden Parameter:
x
y Die Ausdrücke, die die Koordinaten der oberen linken Ecke der Box angeben. Es ist standardmäßig
um 0.
Breite, w
Höhe, h
Die Ausdrücke, die die Breite und Höhe der Box angeben; wenn 0 sind sie
als eingegebene Breite und Höhe interpretiert. Es ist standardmäßig 0.
Farbe, Farbe, c
Geben Sie die Farbe des zu schreibenden Felds an. Die allgemeine Syntax dieser Option finden Sie unter
den Abschnitt "Farbe" im ffmpeg-utils-Handbuch. Wird der Sonderwert "invertieren" verwendet,
die Farbe der Boxkante ist die gleiche wie beim Video mit invertierter Luma.
Dicke, t
Der Ausdruck, der die Dicke der Boxkante festlegt. Der Standardwert ist 3.
Unten finden Sie die Liste der akzeptierten Konstanten.
Die Parameter für x, y, w und h und t sind Ausdrücke, die die folgenden Konstanten enthalten:
geben Das Seitenverhältnis der Eingabeanzeige ist dasselbe wie (w / h) * sar.
hsub
vssub
horizontale und vertikale Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
in_h, ih
in_w, iw
Die Eingabebreite und -höhe.
sar Das Seitenverhältnis des Eingabebeispiels.
x
y Die x- und y-Offset-Koordinaten, an denen die Box gezeichnet wird.
w
h Die Breite und Höhe des gezeichneten Felds.
t Die Dicke der gezeichneten Box.
Diese Konstanten erlauben die x, y, w, h und t Ausdrücke, um sich aufeinander zu beziehen, damit Sie
kann beispielsweise "y=x/dar" oder "h=w/dar" angeben.
Beispiele
· Zeichnen Sie einen schwarzen Kasten um den Rand des Eingabebildes:
Ziehkiste
· Zeichnen Sie eine Box mit der Farbe Rot und einer Deckkraft von 50%:
Drawbox=10:20:200:60:[E-Mail geschützt]
Das vorherige Beispiel kann wie folgt spezifiziert werden:
drawbox=x=10:y=20:w=200:h=60:color=[E-Mail geschützt]
· Füllen Sie die Box mit rosa Farbe:
drawbox=x=10:y=10:w=100:h=100:color=[E-Mail geschützt] :t=max
· Zeichnen Sie eine rote 2:2.40-Maske mit 1 Pixeln:
drawbox=x=-t:y=0.5*(ih-iw/2.4)-t:w=iw+t*2:h=iw/2.4+t*2:t=2:c=red
Zeichnungsgrafik, adrawgraph
Zeichnen Sie ein Diagramm mit eingegebenen Video- oder Audio-Metadaten.
Es akzeptiert die folgenden Parameter:
m1 Legen Sie den Metadatenschlüssel für den ersten Frame fest, aus dem Metadatenwerte zum Zeichnen eines Diagramms verwendet werden.
fg1 1. Vordergrundfarbe festlegen.
m2 Legen Sie den Metadatenschlüssel für den zweiten Frame fest, aus dem Metadatenwerte zum Zeichnen eines Diagramms verwendet werden.
fg2 2. Vordergrundfarbe festlegen.
m3 Legen Sie den Metadatenschlüssel für den 3. Frame fest, aus dem Metadatenwerte zum Zeichnen eines Diagramms verwendet werden.
fg3 3. Vordergrundfarbe festlegen.
m4 Legen Sie den Metadatenschlüssel für den vierten Frame fest, aus dem Metadatenwerte zum Zeichnen eines Diagramms verwendet werden.
fg4 4. Vordergrundfarbe festlegen.
Min. Legen Sie den minimalen Wert des Metadatenwerts fest.
max Legen Sie den maximalen Wert des Metadatenwerts fest.
bg Legen Sie die Hintergrundfarbe des Diagramms fest. Standard ist weiß.
Modus
Grafikmodus einstellen.
Verfügbare Werte für den Modus sind:
Bar
Punkt
Linie
Standard ist "Linie".
Schlitten
Stellen Sie den Folienmodus ein.
Verfügbare Werte für die Folie sind:
Rahmen
Zeichnen Sie einen neuen Rahmen, wenn der rechte Rand erreicht ist.
ersetzen
Ersetzen Sie alte Spalten durch neue.
blättern
Scrollen Sie von rechts nach links.
rblättern
Scrollen Sie von links nach rechts.
Standard ist "Rahmen".
Größe
Legen Sie die Größe des Grafikvideos fest. Die Syntax dieser Option finden Sie im "Video Größe" Abschnitt
in ffmpeg-utils manuell. Der Standardwert ist "900x256".
Die Vordergrundfarbausdrücke können die folgenden Variablen verwenden:
MIN Minimaler Wert des Metadatenwerts.
MAX Maximalwert des Metadatenwerts.
VAL Aktueller Metadatenschlüsselwert.
Die Farbe ist als 0xAABBGGRR definiert.
Beispiel mit Metadaten von Signalstatistiken Filter:
signalstats,drawgraph=lavfi.signalstats.YAVG:min=0:max=255
Beispiel mit Metadaten von ebur128 Filter:
ebur128=metadata=1,adrawgraph=lavfi.r128.M:min=-120:max=5
Zuggitter
Zeichnen Sie ein Raster auf das Eingabebild.
Es akzeptiert die folgenden Parameter:
x
y Die Ausdrücke, die die Koordinaten eines Gitterschnittpunkts angeben
(zur Konfiguration des Offsets). Beide sind standardmäßig auf 0 eingestellt.
Breite, w
Höhe, h
Die Ausdrücke, die die Breite und Höhe der Gitterzelle angeben, wenn sie 0 sind, sind sie
interpretiert als eingegebene Breite bzw. Höhe minus "Dicke", also Bild
wird eingerahmt. Standardmäßig auf 0.
Farbe, Farbe, c
Geben Sie die Farbe des Rasters an. Die allgemeine Syntax dieser Option finden Sie im
Abschnitt "Farbe" im ffmpeg-utils-Handbuch. Wird der Sonderwert "invertieren" verwendet, ist die
Die Rasterfarbe ist die gleiche wie beim Video mit invertierter Luma.
Dicke, t
Der Ausdruck, der die Dicke der Rasterlinie festlegt. Der Standardwert ist 1.
Unten finden Sie die Liste der akzeptierten Konstanten.
Die Parameter für x, y, w und h und t sind Ausdrücke, die die folgenden Konstanten enthalten:
geben Das Seitenverhältnis der Eingabeanzeige ist dasselbe wie (w / h) * sar.
hsub
vssub
horizontale und vertikale Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
in_h, ih
in_w, iw
Die Breite und Höhe der Eingabegitterzelle.
sar Das Seitenverhältnis des Eingabebeispiels.
x
y Die x- und y-Koordinaten eines Gitterschnittpunkts (zur Konfiguration
versetzt).
w
h Die Breite und Höhe der gezeichneten Zelle.
t Die Dicke der gezeichneten Zelle.
Diese Konstanten erlauben die x, y, w, h und t Ausdrücke, um sich aufeinander zu beziehen, damit Sie
kann beispielsweise "y=x/dar" oder "h=w/dar" angeben.
Beispiele
· Zeichnen Sie ein Gitter mit Zelle 100x100 Pixel, Dicke 2 Pixel, mit Farbe Rot und An
Opazität von 50%:
Drawgrid=Breite=100:Höhe=100:Dicke=2:Farbe=[E-Mail geschützt]
· Zeichnen Sie ein weißes 3x3-Raster mit einer Deckkraft von 50%:
drawgrid=w=iw/3:h=ih/3:t=2:c=[E-Mail geschützt]
Zeichentext
Zeichnen Sie eine Textzeichenfolge oder einen Text aus einer angegebenen Datei über ein Video mit dem libfreetype
Bibliothek.
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie FFmpeg mit konfigurieren
"--enable-libfreetype". So aktivieren Sie den Standardfont-Fallback und die Schriftart Option, die du brauchst
konfigurieren Sie FFmpeg mit "--enable-libfontconfig". Um das zu aktivieren text_shaping Option, du
muss FFmpeg mit "--enable-libfribidi" konfigurieren.
Syntax
Es akzeptiert die folgenden Parameter:
Box Wird verwendet, um mit der Hintergrundfarbe einen Rahmen um den Text zu zeichnen. Der Wert muss entweder 1 . sein
(aktivieren) oder 0 (deaktivieren). Der Standardwert von Box ist 0.
Kastenrandw
Stellen Sie die Breite des Rahmens ein, der um die Box gezogen werden soll mit Boxfarbe. Der Standard
Wert von Kastenrandw ist 0.
Boxfarbe
Die Farbe, die zum Zeichnen eines Rahmens um den Text verwendet werden soll. Die Syntax dieser Option finden Sie unter
den Abschnitt "Farbe" im ffmpeg-utils-Handbuch.
Der Standardwert von Boxfarbe ist weiß".
Borderw
Stellen Sie mit die Breite des um den Text zu zeichnenden Rahmens ein Randfarbedem „Vermischten Geschmack“. Seine
Standardwert von Borderw ist 0.
Randfarbe
Legen Sie die Farbe fest, die zum Zeichnen eines Rahmens um den Text verwendet werden soll. Für die Syntax davon
Option finden Sie im Abschnitt "Farbe" im Handbuch zu ffmpeg-utils.
Der Standardwert von Randfarbe ist schwarz".
Expansion
Wählen Sie aus, wie die Text wird erweitert. Kann entweder "none", "strftime" (veraltet) oder . sein
"normal" (Standard). Siehe die drawtext_expansion, Text Expansion Abschnitt unten für
Details.
fix_bounds
Wenn wahr, überprüfen und korrigieren Sie die Textkoordinaten, um ein Abschneiden zu vermeiden.
Schriftfarbe
Die Farbe, die zum Zeichnen von Schriftarten verwendet werden soll. Die Syntax dieser Option finden Sie im
Abschnitt "Farbe" im ffmpeg-utils-Handbuch.
Der Standardwert von Schriftfarbe ist schwarz".
Fontcolor_expr
String, der genauso erweitert wird wie Text um Dynamik zu erhalten Schriftfarbe Wert. Durch
Standardmäßig hat diese Option einen leeren Wert und wird nicht verarbeitet. Wenn diese Option eingestellt ist, ist es
Überschreibungen Schriftfarbe .
Schriftart
Die zum Zeichnen von Text zu verwendende Schriftfamilie. Standardmäßig Sans.
Schriftdatei
Die Schriftartdatei, die zum Zeichnen von Text verwendet werden soll. Der Pfad muss angegeben werden. Dieser Parameter
ist obligatorisch, wenn die fontconfig-Unterstützung deaktiviert ist.
zeichnen
Diese Option existiert nicht, bitte beachten Sie das Zeitleistensystem
Alpha
Zeichnen Sie den Text mit Alpha-Blending. Der Wert kann entweder eine Zahl zwischen 0.0
und 1.0 Der Ausdruck akzeptiert die gleichen Variablen x, y tun. Der Standardwert ist 1.
Siehe fontcolor_expr
Schriftgröße
Die zum Zeichnen von Text zu verwendende Schriftgröße. Der Standardwert von Schriftgröße ist 16.
text_shaping
Wenn der Wert auf 1 gesetzt ist, versuchen Sie, den Text zu formen (umkehren Sie beispielsweise die Reihenfolge von rechts nach rechts).
linken Text und verbinden arabische Zeichen), bevor Sie ihn zeichnen. Ansonsten zeichne einfach die
Text genau wie angegeben. Standardmäßig 1 (sofern unterstützt).
ft_load_flags
Die Flags, die zum Laden der Schriftarten verwendet werden sollen.
Die Flags bilden die entsprechenden Flags ab, die von libfreetype unterstützt werden, und sind eine Kombination
der folgenden Werte:
Standard
no_scale
kein_hinting
Ausbeute
no_bitmap
vertikales_layout
force_autohint
Crop_Bitmap
pedantisch
ignore_global_advance_width
no_recurse
ignorieren_transformieren
monochrom
lineares_design
no_autohint
Der Standardwert ist "Standard".
Weitere Informationen finden Sie in der Dokumentation zu den FT_LOAD_* libfreetype-Flags.
Schattenfarbe
Die Farbe, die zum Zeichnen eines Schattens hinter dem gezeichneten Text verwendet werden soll. Für die Syntax von
Überprüfen Sie diese Option im Abschnitt "Farbe" im Handbuch zu ffmpeg-utils.
Der Standardwert von Schattenfarbe ist schwarz".
Schattenx
schattig
Die x- und y-Offsets für die Textschattenposition in Bezug auf die Position des
Text. Sie können entweder positive oder negative Werte sein. Der Standardwert für beide ist
"0".
Startnummer
Die Startbildnummer für die Variable n/frame_num. Der Standardwert ist "0".
Tabgröße
Die Größe in Anzahl der Leerzeichen, die zum Rendern der Registerkarte verwendet werden soll. Der Standardwert ist 4.
Timecode
Stellen Sie die anfängliche Timecode-Darstellung im Format "hh:mm:ss[:;.]ff" ein. Es kann benutzt werden
mit oder ohne Textparameter. timecode_rate Option muss angegeben werden.
timecode_rate, Bewertung, r
Stellen Sie die Timecode-Bildrate ein (nur Timecode).
Text
Die zu zeichnende Textzeichenfolge. Der Text muss eine Folge von UTF-8-codierten Zeichen sein.
Dieser Parameter ist obligatorisch, wenn keine Datei mit dem Parameter angegeben wird Textdatei.
Textdatei
Eine Textdatei, die zu zeichnenden Text enthält. Der Text muss eine Sequenz von UTF-8-kodiert sein
Zeichen.
Dieser Parameter ist obligatorisch, wenn beim Parameter kein Textstring angegeben wird Text.
Wenn beides Text und Textdatei angegeben sind, wird ein Fehler ausgegeben.
neu laden
Wenn auf 1 gesetzt, wird die Textdatei wird vor jedem Frame neu geladen. Aktualisieren Sie es unbedingt
atomar, oder es kann teilweise gelesen werden oder sogar fehlschlagen.
x
y Die Ausdrücke, die die Versätze angeben, an denen Text innerhalb des Videos gezeichnet wird
Rahmen. Sie sind relativ zum oberen/linken Rand des Ausgabebilds.
Der Standardwert von x und y ist "0".
Nachfolgend finden Sie die Liste der akzeptierten Konstanten und Funktionen.
Die Parameter für x und y sind Ausdrücke mit den folgenden Konstanten und
Funktionen:
geben das Seitenverhältnis der Eingabeanzeige ist dasselbe wie (w / h) * sar
hsub
vssub
horizontale und vertikale Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
Zeile_h, lh
die Höhe jeder Textzeile
main_h, h, H
die Eingabehöhe
main_w, w, W
die Eingabebreite
max_glyph_a, Aufstieg
der maximale Abstand von der Grundlinie zur höchsten/oberen Gitterkoordinate, die verwendet wird, um
Platzieren Sie einen Glyphen-Umrisspunkt für alle gerenderten Glyphen. Es ist ein positiver Wert, wegen
zur Ausrichtung des Rasters mit der Y-Achse nach oben.
max_glyph_d, Abstammung
der maximale Abstand von der Grundlinie zur niedrigsten Gitterkoordinate, die verwendet wird, um a . zu platzieren
Glyphenumrisspunkt für alle gerenderten Glyphen. Dies ist ein negativer Wert, da
die Ausrichtung des Rasters, mit der Y-Achse nach oben.
max_glyph_h
maximale Glyphenhöhe, das ist die maximale Höhe für alle Glyphen, die im
gerenderten Text ist äquivalent zu Aufstieg - Abstammung.
max_glyph_w
maximale Glyphenbreite, das ist die maximale Breite für alle Glyphen, die im
gerenderter Text
n die Anzahl der Eingaberahmen, beginnend bei 0
Rand(min, max)
Gib eine Zufallszahl zwischen zurück Min. und max
sar Das Seitenverhältnis des Eingabebeispiels.
t Zeitstempel in Sekunden ausgedrückt, NAN, wenn der Eingabezeitstempel unbekannt ist
text_h, th
die Höhe des gerenderten Textes
text_w, tw
die Breite des gerenderten Textes
x
y die x- und y-Offset-Koordinaten, an denen der Text gezeichnet wird.
Diese Parameter ermöglichen die x und y Ausdrücke, um aufeinander zu verweisen, damit Sie für
Beispiel "y=x/dar" angeben.
Text Expansion
If Expansion auf "strftime" eingestellt ist, erkennt der Filter strftime () Sequenzen in der
bereitgestellten Text und erweitert diese entsprechend. Überprüfen Sie die Dokumentation von strftime (). Dies
Funktion ist veraltet.
If Expansion auf "none" gesetzt ist, wird der Text wörtlich ausgedruckt.
If Expansion auf "normal" gesetzt ist (was die Standardeinstellung ist), der folgende Erweiterungsmechanismus
wird eingesetzt.
Das Backslash-Zeichen \, gefolgt von einem beliebigen Zeichen, wird immer auf die Sekunde erweitert
Charakter.
Sequenz der Form "%{...}" werden expandiert. Der Text zwischen den Klammern ist eine Funktion
Name, möglicherweise gefolgt von durch ':' getrennten Argumenten. Wenn die Argumente special enthalten
Zeichen oder Trennzeichen (':' oder '}'), sollten sie mit Escapezeichen versehen werden.
Beachten Sie, dass sie wahrscheinlich auch als Wert für die maskiert werden müssen Text Option in der
Filterargument-String und als Filterargument in der Filtergraph-Beschreibung und
möglicherweise auch für die Hülle, die bis zu vier Fluchtstufen ausmacht; mit einer Textdatei
vermeidet diese Probleme.
Folgende Funktionen stehen zur Verfügung:
Ausdruck, e
Das Ergebnis der Ausdrucksbewertung.
Es muss ein Argument annehmen, das den auszuwertenden Ausdruck angibt, der die
gleiche Konstanten und Funktionen wie die x und y Werte. Beachten Sie, dass nicht alle Konstanten
verwendet werden, zum Beispiel ist die Textgröße bei der Auswertung des Ausdrucks nicht bekannt, so dass die
konstante text_w und text_h einen undefinierten Wert haben.
expr_int_format, wenn
Werten Sie den Wert des Ausdrucks aus und geben Sie ihn als formatierte Ganzzahl aus.
Das erste Argument ist der auszuwertende Ausdruck, ebenso wie für die ausdr Funktion.
Das zweite Argument gibt das Ausgabeformat an. Zulässige Werte sind x, X, d und u.
Sie werden genau wie in der Funktion "printf" behandelt. Der dritte Parameter ist optional
und legt die Anzahl der Positionen fest, die der Ausgang einnimmt. Es kann verwendet werden, um Polsterungen hinzuzufügen
mit Nullen von links.
gmtime
Die Zeit, zu der der Filter ausgeführt wird, ausgedrückt in UTC. Es kann ein Argument akzeptieren:
a strftime () Zeichenfolgenformat.
Ortszeit
Die Zeit, zu der der Filter ausgeführt wird, ausgedrückt in der lokalen Zeitzone. Es kann
akzeptiere ein Argument: a strftime () Zeichenfolgenformat.
Metadaten
Frame-Metadaten. Es muss ein Argument annehmen, das den Metadatenschlüssel angibt.
n, Frame_num
Die Rahmennummer, beginnend bei 0.
Bildtyp
Eine 1-stellige Beschreibung des aktuellen Bildtyps.
pts Der Zeitstempel des aktuellen Frames. Es kann bis zu zwei Argumente aufnehmen.
Das erste Argument ist das Format des Zeitstempels; es ist standardmäßig "flt" für Sekunden als
eine Dezimalzahl mit Mikrosekundengenauigkeit; "hms" steht für ein formatiertes
[-]HH:MM:SS.mmm Zeitstempel mit Millisekunden-Genauigkeit.
Das zweite Argument ist ein Offset, der dem Zeitstempel hinzugefügt wird.
Beispiele
· Zeichnen Sie "Testtext" mit der Schriftart FreeSerif und verwenden Sie die Standardwerte für das optionale
Parameter.
drawtext="fontfile=/usr/share/fonts/truetype/freefont/FreeSerif.ttf: text='Testtext'"
· Zeichnen Sie 'Testtext' mit Schriftart FreeSerif der Größe 24 an Position x=100 und y=50 (Zählen
von der oberen linken Ecke des Bildschirms) ist der Text gelb mit einem roten Rahmen um ihn herum. Beide
Text und Rahmen haben eine Deckkraft von 20 %.
drawtext="fontfile=/usr/share/fonts/truetype/freefont/FreeSerif.ttf: text='Testtext':\
x=100: y=50: Schriftgröße=24: Schriftfarbe=[E-Mail geschützt] : box=1: boxfarbe=[E-Mail geschützt] "
Beachten Sie, dass die doppelten Anführungszeichen nicht erforderlich sind, wenn innerhalb des keine Leerzeichen verwendet werden
Parameterliste.
· Zeigen Sie den Text in der Mitte des Videorahmens an:
drawtext="fontsize=30:fontfile=FreeSerif.ttf:text='Hallo Welt':x=(w-text_w)/2:y=(h-text_h)/2"
· Zeigen Sie in der letzten Zeile des Videoframes eine Textzeile an, die von rechts nach links gleitet. Der
Datei LANGE LINIE Es wird angenommen, dass es eine einzelne Zeile ohne Zeilenumbrüche enthält.
drawtext="fontsize=15:fontfile=FreeSerif.ttf:text=LONG_LINE:y=h-line_h:x=-50*t"
· Zeigen Sie den Inhalt der Datei an CREDITS unten aus dem Rahmen und scrollen Sie nach oben.
drawtext="fontsize=20:fontfile=FreeSerif.ttf:textfile=CREDITS:y=h-20*t"
· Zeichnen Sie einen einzelnen grünen Buchstaben "g" in die Mitte des Eingangsvideos. Die Glyphen-Grundlinie
wird auf halber Bildschirmhöhe platziert.
drawtext="fontsize=60:fontfile=FreeSerif.ttf:fontcolor=green:text=g:x=(w-max_glyph_w)/2:y=h/2-Aufstieg"
· Text alle 1 Sekunden für 3 Sekunde anzeigen:
drawtext="fontfile=FreeSerif.ttf:fontcolor=white:x=100:y=x/dar:enable=lt(mod(t\,3)\,1):text='blink'"
· Verwenden Sie fontconfig, um die Schriftart einzustellen. Beachten Sie, dass die Doppelpunkte mit Escapezeichen versehen werden müssen.
drawtext='fontfile=Linux Libertine O-40\:style=Semibold:text=FFmpeg'
· Drucken Sie das Datum einer Echtzeit-Kodierung (siehe strftime(3)):
drawtext='fontfile=FreeSans.ttf:text=%{localtime\:%a %b %d %Y}'
· Ein- und Ausblenden von Text anzeigen (erscheinen/verschwinden):
#!/ Bin / sh
DS=1.0 # Anzeigestart
DE=10.0 # Anzeigeende
FID=1.5 # Einblenddauer
FOD=5 # Ausblenddauer
ffplay -f lavfi "color,drawtext=text=TEST:fontsize=50:fontfile=FreeSerif.ttf:fontcolor_expr=ff0000%{eif\\\\: clip(255*(1* between(t\\, $DS + $FID\\, $DE - $FOD) + ((t - $DS)/$FID)*zwischen(t\\, $DS\\, $DS + $FID) + (-(t - $DE) /$FOD)*zwischen(t\\, $DE - $FOD\\, $DE) )\\, 0\\, 255) \\\\: x\\\\: 2 }"
Weitere Informationen zu libfreetype finden Sie unter:http://www.freetype.org/>.
Weitere Informationen zu fontconfig finden Sie unter:
<http://freedesktop.org/software/fontconfig/fontconfig-user.html>.
Weitere Informationen zu libfribidi finden Sie unter:http://fribidi.org/>.
Kantenerkennung
Kanten erkennen und zeichnen. Der Filter verwendet den Canny Edge Detection-Algorithmus.
Der Filter akzeptiert die folgenden Optionen:
niedrig
Highs
Legen Sie niedrige und hohe Schwellenwerte fest, die vom Canny-Schwellenwert-Algorithmus verwendet werden.
Die hohe Schwelle wählt die "starken" Kantenpixel aus, die dann durchgeschaltet werden
8-Konnektivität mit den "schwachen" Kantenpixeln, die durch den niedrigen Schwellenwert ausgewählt werden.
niedrig und Highs Schwellenwerte müssen im Bereich [0,1] gewählt werden, und niedrig sollte sein
kleiner oder gleich Highs.
Standardwert für niedrig ist "20/255" und Standardwert für Highs ist "50/255".
Modus
Definieren Sie den Zeichenmodus.
Drähte
Zeichnen Sie weiße/graue Drähte auf schwarzem Hintergrund.
Colormix
Mischen Sie die Farben, um einen Farb-/Cartoon-Effekt zu erzielen.
Standardwert ist Drähte.
Beispiele
· Standard-Flankenerkennung mit benutzerdefinierten Werten für die Hysterese-Schwelle:
Kantenerkennung=niedrig=0.1:hoch=0.4
· Maleffekt ohne Schwellen:
edgedetect=mode=colormix:high=0
eq
Stellen Sie Helligkeit, Kontrast, Sättigung und ungefähre Gamma-Anpassung ein.
Der Filter akzeptiert die folgenden Optionen:
Kontrast
Stellen Sie den Kontrastausdruck ein. Der Wert muss ein Gleitkommawert im Bereich "-2.0" bis 2.0 sein.
Der Standardwert ist "0".
Helligkeit
Stellen Sie den Helligkeitsausdruck ein. Der Wert muss ein Gleitkommawert im Bereich "-1.0" bis 1.0 sein.
Der Standardwert ist "0".
Sättigung
Stellen Sie den Sättigungsausdruck ein. Der Wert muss ein Float im Bereich von 0.0 bis 3.0 sein. Der
Standardwert ist "1".
Gamma
Stellen Sie den Gamma-Ausdruck ein. Der Wert muss ein Float im Bereich von 0.1 bis 10.0 sein. Der Standard
Wert ist "1".
gamma_r
Stellen Sie den Gamma-Ausdruck für Rot ein. Der Wert muss ein Float im Bereich von 0.1 bis 10.0 sein. Der
Standardwert ist "1".
gamma_g
Legen Sie den Gamma-Ausdruck für Grün fest. Der Wert muss ein Float im Bereich von 0.1 bis 10.0 sein.
Der Standardwert ist "1".
gamma_b
Legen Sie den Gamma-Ausdruck für Blau fest. Der Wert muss ein Float im Bereich von 0.1 bis 10.0 sein. Der
Standardwert ist "1".
gamma_gewicht
Legen Sie den Gamma-Gewichtungsausdruck fest. Es kann verwendet werden, um die Wirkung eines hohen Gamma zu reduzieren
Wert auf helle Bildbereiche, z. B. verhindern, dass sie zu stark verstärkt werden und einfach nur klar
Weiß. Der Wert muss ein Float im Bereich von 0.0 bis 1.0 sein. Ein Wert von 0.0 dreht das Gamma
Korrektur ganz nach unten, während 1.0 seine volle Stärke belässt. Der Standardwert ist "1".
eval
Stellen Sie ein, wenn die Ausdrücke für Helligkeit, Kontrast, Sättigung und Gamma-Ausdrücke
bewertet werden.
Es akzeptiert die folgenden Werte:
init
werte Ausdrücke nur einmal während der Filterinitialisierung aus oder wenn ein Befehl
wird verarbeitet
Rahmen
werte Ausdrücke für jeden eingehenden Frame aus
Standardwert ist init.
Die Ausdrücke akzeptieren die folgenden Parameter:
n Frameanzahl des Eingabeframes beginnend bei 0
Post Byte-Position des entsprechenden Pakets in der Eingabedatei, NAN wenn nicht angegeben
r Bildrate des Eingangsvideos, NAN, wenn die Eingangsbildrate unbekannt ist
t Zeitstempel in Sekunden ausgedrückt, NAN, wenn der Eingabezeitstempel unbekannt ist
Befehle
Der Filter unterstützt die folgenden Befehle:
Kontrast
Stellen Sie den Kontrastausdruck ein.
Helligkeit
Stellen Sie den Helligkeitsausdruck ein.
Sättigung
Stellen Sie den Sättigungsausdruck ein.
Gamma
Stellen Sie den Gamma-Ausdruck ein.
gamma_r
Legen Sie den gamma_r-Ausdruck fest.
gamma_g
Gamma_g-Ausdruck festlegen.
gamma_b
gamma_b-Ausdruck festlegen.
gamma_gewicht
Gamma_weight-Ausdruck festlegen.
Der Befehl akzeptiert dieselbe Syntax wie die entsprechende Option.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
Erosion
Wenden Sie den Erosionseffekt auf das Video an.
Dieser Filter ersetzt das Pixel durch das aus einer regionalen(3x3) mindestens.
Es akzeptiert die folgenden Optionen:
Schwelle0
Schwelle1
Schwelle2
Schwelle3
Begrenzen Sie die maximale Änderung für jede Ebene, der Standardwert ist 65535. Bei 0 bleibt die Ebene bestehen
unverändert.
Koordinaten
Flag, das das Pixel angibt, auf das verwiesen werden soll. Der Standardwert ist 255, dh alle acht Pixel sind
benutzt.
Flaggen zu lokalen 3x3-Koordinatenkarten wie folgt:
1 2 3
4 5
6 7 8
Extraktionsflugzeuge
Extrahieren Sie Farbkanalkomponenten aus dem Eingangsvideostream in ein separates Graustufenvideo
Bächen.
Der Filter akzeptiert die folgende Option:
Flugzeuge
Legen Sie die zu extrahierende(n) Ebene(n) fest.
Verfügbare Werte für Flugzeuge sind:
y
u
v
a
r
g
b
Die Auswahl von Ebenen, die in der Eingabe nicht verfügbar sind, führt zu einem Fehler. Das heißt du
Die Ebenen "r", "g", "b" und "y", "u", "v" können nicht gleichzeitig ausgewählt werden.
Beispiele
· Extrahieren Sie die Luma-, u- und v-Farbkanalkomponente aus dem Eingangsvideoframe in 3 Graustufen
Ausgänge:
ffmpeg -i video.avi -filter_complex 'extractplanes=y+u+v[y][u][v]' -map '[y]' y.avi -map '[u]' u.avi -map '[ v]' v.avi
elbg
Wenden Sie einen Posterize-Effekt mit dem ELBG-Algorithmus (Enhanced LBG) an.
Für jedes Eingabebild berechnet der Filter die optimale Zuordnung von der Eingabe zu den
Ausgabe bei gegebener Codebuchlänge, d. h. der Anzahl der unterschiedlichen Ausgabefarben.
Dieser Filter akzeptiert die folgenden Optionen.
Codebuch_Länge, l
Codebuchlänge einstellen. Der Wert muss eine positive ganze Zahl sein und stellt die Zahl dar
von unterschiedlichen Ausgabefarben. Der Standardwert ist 256.
nb_schritte, n
Legen Sie die maximale Anzahl von Iterationen fest, die für die Berechnung der optimalen Zuordnung angewendet werden sollen. Der
Je höher der Wert, desto besser das Ergebnis und desto höher die Rechenzeit. Standard
Wert ist 1.
Samen, s
Setzt einen zufälligen Seed, muss eine ganze Zahl zwischen 0 und UINT32_MAX sein. Wenn nicht
angegeben oder wenn explizit auf -1 gesetzt, versucht der Filter, einen guten zufälligen Startwert zu verwenden
auf Best-Effort-Basis.
pal8
Legen Sie das Ausgabepixelformat von pal8 fest. Diese Option funktioniert nicht mit einer Codebuchlänge größer
als 256.
verblassen
Wenden Sie einen Ein-/Ausblendeffekt auf das Eingangsvideo an.
Es akzeptiert die folgenden Parameter:
Art, t
Der Effekttyp kann entweder "in" für einen Fade-In oder "Out" für einen Fade-Out-Effekt sein.
Standard ist "in".
start_frame, s
Geben Sie die Nummer des Frames an, bei dem der Fade-Effekt angewendet werden soll. Standard ist 0.
nb_frames, n
Die Anzahl der Frames, die der Fade-Effekt andauert. Am Ende des Einblendeffekts wird der
Das Ausgabevideo hat die gleiche Intensität wie das Eingabevideo. Am Ende des Fade-
Out-Übergang wird das Ausgabevideo mit dem ausgewählten gefüllt Farbe. Standard ist
25
Alpha
Wenn auf 1 gesetzt, blendet nur der Alphakanal ein, falls einer am Eingang vorhanden ist. Der Standardwert ist 0.
Startzeit, st
Geben Sie den Zeitstempel (in Sekunden) des Frames an, um mit der Anwendung des Fade-Effekts zu beginnen. Wenn
sowohl start_frame als auch start_time sind angegeben, die Überblendung beginnt wann immer es kommt
zuletzt. Standard ist 0.
Dauer, d
Die Anzahl der Sekunden, die der Fade-Effekt andauern muss. Am Ende der Einblendung
Effekt hat das Ausgabevideo die gleiche Intensität wie das Eingabevideo am Ende von
der Fade-Out-Übergang das Ausgabevideo wird mit dem ausgewählten gefüllt Farbe. Wenn
Sowohl die Dauer als auch nb_frames werden angegeben, die Dauer wird verwendet. Standard ist 0 (nb_frames
wird standardmäßig verwendet).
Farbe, Farbe, c
Geben Sie die Farbe der Überblendung an. Standard ist "schwarz".
Beispiele
· Blenden Sie die ersten 30 Frames des Videos ein:
einblenden=in:0:30
Der obige Befehl ist äquivalent zu:
Fade=t=in:s=0:n=30
· Blenden Sie die letzten 45 Frames eines 200-Frame-Videos aus:
ausblenden=aus:155:45
fade=type=out:start_frame=155:nb_frames=45
· Einblenden der ersten 25 Frames und Ausblenden der letzten 25 Frames eines 1000-Frame-Videos:
Fade=in:0:25, Fade=out:975:25
· Machen Sie die ersten 5 Frames gelb und blenden Sie dann von Frame 5-24 ein:
Einblenden=in:5:20:Farbe=Gelb
· Alpha über die ersten 25 Frames des Videos einblenden:
einblenden=in:0:25:alpha=1
· Die ersten 5.5 Sekunden schwarz machen, dann 0.5 Sekunden einblenden:
Fade=t=in:st=5.5:d=0.5
fftfilt
Wenden Sie beliebige Ausdrücke auf Samples im Frequenzbereich an
dc_Y
Passen Sie den DC-Wert (Verstärkung) der Luma-Ebene des Bildes an. Der Filter akzeptiert ein
ganzzahliger Wert im Bereich von 0 bis 1000. Der Standardwert ist 0.
dc_U
Passen Sie den DC-Wert (Gain) der 1. Chroma-Ebene des Bildes an. Der Filter akzeptiert ein
ganzzahliger Wert im Bereich von 0 bis 1000. Der Standardwert ist 0.
dc_V
Passen Sie den DC-Wert (Gain) der 2. Chroma-Ebene des Bildes an. Der Filter akzeptiert ein
ganzzahliger Wert im Bereich von 0 bis 1000. Der Standardwert ist 0.
gewichtig
Legen Sie den Gewichtungsausdruck im Frequenzbereich für die Luma-Ebene fest.
Gewicht_U
Legen Sie den Gewichtungsausdruck im Frequenzbereich für die 1. Chroma-Ebene fest.
Gewicht_V
Stellen Sie den Gewichtungsausdruck im Frequenzbereich für die 2. Chroma-Ebene ein.
Der Filter akzeptiert die folgenden Variablen:
X
Y Die Koordinaten des aktuellen Samples.
W
H Die Breite und Höhe des Bildes.
Beispiele
· Hochpass:
fftfilt=dc_Y=128:weight_Y='squish(1-(Y+X)/100)'
· Tiefpass:
fftfilt=dc_Y=0:weight_Y='squish((Y+X)/100-1)'
· Schärfen:
fftfilt=dc_Y=0:weight_Y='1+squish(1-(Y+X)/100)'
Feld
Extrahieren Sie ein einzelnes Halbbild aus einem Zeilensprungbild mit Schrittarithmetik, um Verschwendung zu vermeiden
CPU-Zeit. Die Ausgabeframes werden als non-interlaced gekennzeichnet.
Der Filter akzeptiert die folgenden Optionen:
tippe
Geben Sie an, ob das obere (wenn der Wert 0 oder "top" ist) oder das untere Feld extrahiert werden soll
(wenn der Wert 1 oder "unten" ist).
Feldübereinstimmung
Feldanpassungsfilter für inverse Telecine. Es soll das Fortschrittliche rekonstruieren
Frames aus einem Telecined-Stream. Der Filter lässt keine duplizierten Frames fallen, um zu erreichen
einem vollständigen inversen Telecine-"Fieldmatch" muss ein Dezimationsfilter folgen, wie z
as dezimieren in der Filtergrafik.
Die Trennung von Feldanpassung und Dezimierung wird insbesondere durch die
Möglichkeit, einen De-Interlacing-Filter-Fallback zwischen den beiden einzufügen. Wenn die Quelle
hat Telecined- und Real-Interlaced-Inhalte gemischt, "fieldmatch" kann nicht übereinstimmen
Felder für die verschachtelten Teile. Aber diese verbleibenden gekämmten Rahmen werden als
interlaced und kann daher durch einen späteren Filter wie z. B. de-interlaced werden jadif bevor
Dezimierung.
Neben den verschiedenen Konfigurationsmöglichkeiten kann "fieldmatch" eine optionale Sekunde dauern
Stream, aktiviert durch den ppsrc Möglichkeit. Wenn aktiviert, wird die Frame-Rekonstruktion
basierend auf den Feldern und Frames aus diesem zweiten Stream. Dies ermöglicht die erste Eingabe
vorverarbeitet, um die verschiedenen Algorithmen des Filters zu unterstützen, während die
verlustfreie Ausgabe (vorausgesetzt, die Felder sind richtig zugeordnet). Typischerweise ist ein feldbewusster
Denoiser oder Helligkeits-/Kontrastanpassungen können hilfreich sein.
Beachten Sie, dass dieser Filter die gleichen Algorithmen verwendet wie TIVTC/TFM (AviSynth-Projekt) und
VIVTC/VFM (VapourSynth-Projekt). Letzteres ist ein leichter Klon von TFM, aus dem "fieldmatch"
basiert auf. Obwohl Semantik und Verwendung sehr nah beieinander liegen, werden einige Verhaltens- und Optionsnamen
abweichen können.
Die dezimieren Filter funktioniert derzeit nur für die Eingabe mit konstanter Bildrate. Wenn Ihre Eingabe hat
gemischte telecined (30fps) und progressive Inhalte mit einer niedrigeren Framerate wie 24fps verwenden die
folgende Filterkette, um den notwendigen cfr-Stream zu erzeugen:
"dejudder,fps=30000/1001,fieldmatch,dezimieren".
Der Filter akzeptiert die folgenden Optionen:
Auftrag
Geben Sie die angenommene Feldreihenfolge des Eingabestreams an. Verfügbare Werte sind:
Auto
Parität automatisch erkennen (verwenden Sie den internen Paritätswert von FFmpeg).
bff Nehmen Sie zuerst das untere Feld an.
tff Nehmen Sie zuerst das obere Feld an.
Beachten Sie, dass manchmal empfohlen wird, der vom Stream angekündigten Parität nicht zu vertrauen.
Standardwert ist Auto.
Modus
Legen Sie den zu verwendenden Matching-Modus oder die zu verwendende Strategie fest. pc Modus ist der sicherste in dem Sinne, dass er
riskiert nach Möglichkeit kein Ruckeln durch doppelte Frames, aber wenn es welche gibt
Bei schlechten Bearbeitungen oder gemischten Feldern werden gekämmte Frames ausgegeben, wenn eine gute Übereinstimmung besteht
könnte es tatsächlich geben. Auf der anderen Seite, pcn_ub Modus ist der riskanteste in Bezug auf
erzeugt Ruckeln, findet aber fast immer einen guten Rahmen, wenn einer vorhanden ist. Der
andere Werte liegen alle dazwischen pc und pcn_ub in Bezug auf das Risiko von Ruckeln
und das Erstellen von doppelten Frames im Vergleich zum Finden guter Übereinstimmungen in Abschnitten mit schlechten Bearbeitungen,
verwaiste Felder, gemischte Felder usw.
Weitere Details zu p/c/n/u/b finden Sie in p/c/n/u/b Bedeutung .
Verfügbare Werte sind:
pc 2-Wege-Matching (p/c)
pc_n
2-Wege-Matching und drittes Match versuchen, wenn noch gekämmt (p/c + n)
pc_u
2-Wege-Matching und drittes Match (gleiche Reihenfolge) versuchen, wenn immer noch gekämmt (p/c + u)
pc_n_ub
2-Wege-Matching, 3. Match versuchen, wenn immer noch gekämmt, und 4./5. Match versuchen, wenn
noch gekämmt (p/c + n + u/b)
pcn 3-Wege-Matching (p/c/n)
pcn_ub
3-Wege-Matching und 4./5.-Matches versuchen, wenn alle 3 der Original-Matches sind
als gekämmt erkannt (p/c/n + u/b)
Die Klammern am Ende geben die Übereinstimmungen an, die für diesen Modus verwendet werden würden
angenommen Auftrag=tff (und Feld on Auto or Top).
In Sachen Geschwindigkeit pc Modus ist mit Abstand der schnellste und pcn_ub ist am langsamsten.
Standardwert ist pc_n.
ppsrc
Markieren Sie den Haupteingabestrom als vorverarbeitete Eingabe und aktivieren Sie die sekundäre Eingabe
stream als saubere Quelle für die Auswahl der Felder. Siehe die Filter-Einführung für
mehr Details. Es ist ähnlich wie die clip2 Funktion von VFM/TFM.
Der Standardwert ist 0 (deaktiviert).
Feld
Legen Sie das Feld fest, von dem abgeglichen werden soll. Es wird empfohlen, diesen auf den gleichen Wert einzustellen wie Auftrag
es sei denn, bei dieser Einstellung treten Übereinstimmungsfehler auf. Unter bestimmten Umständen
Das Ändern des Felds, das für die Übereinstimmung verwendet wird, kann einen großen Einfluss auf die Übereinstimmung haben
Leistung. Verfügbare Werte sind:
Auto
Automatisch (gleicher Wert wie Auftrag).
Boden
Match aus dem unteren Feld.
Top Match aus dem oberen Feld.
Standardwert ist Auto.
Chroma
Legen Sie fest, ob Chroma bei den Übereinstimmungsvergleichen berücksichtigt wird oder nicht. In den meisten Fällen ist es
Es wird empfohlen, dies aktiviert zu lassen. Sie sollten dies nur auf 0 setzen, wenn Ihr Clip über
schlechte Chroma-Probleme wie starkes Rainbowing oder andere Artefakte. Setzen Sie dies auf 0
könnte auch verwendet werden, um die Dinge auf Kosten einer gewissen Genauigkeit zu beschleunigen.
Der Standardwert ist 1.
y0
y1 Diese definieren ein Ausschlussband, das die Linien zwischen . ausschließt y0 und y1 vom Sein
in die Field Matching-Entscheidung einbezogen. Ein Ausschlussband kann verwendet werden, um zu ignorieren
Untertitel, ein Logo oder andere Dinge, die den Abgleich stören können. y0 setzt die
Scanlinie starten und y1 setzt die Endzeile; alle Zeilen dazwischen y0 und y1
(Einschließlich y0 und y1) wird ignoriert. Einstellung y0 und y1 auf den gleichen Wert wird
deaktivieren Sie die Funktion. y0 und y1 standardmäßig auf 0.
scthresh
Stellen Sie den Schwellenwert für die Erkennung von Szenenänderungen als Prozentsatz der maximalen Änderung der Leuchte ein
Flugzeug. Gute Werte liegen im Bereich "[8.0, 14.0]". Szenenwechselerkennung ist nur
relevant im Fall Kampfkampf=sc. Das Sortiment für scthresh ist "[0.0, 100.0]".
Der Standardwert ist 12.0.
Kampfkampf
Wann Combatch ist nicht keine, "fieldmatch" berücksichtigt die gekämmten Scores von
Übereinstimmungen bei der Entscheidung, welche Übereinstimmung als letzte Übereinstimmung verwendet werden soll. Verfügbare Werte sind:
keine
Kein abschließendes Matching basierend auf gekämmten Scores.
sc Gekämmte Scores werden nur verwendet, wenn ein Szenenwechsel erkannt wird.
voller
Verwenden Sie die ganze Zeit gekämmte Scores.
Standardeinstellung ist sc.
Kammdbg
Erzwinge "fieldmatch", um die gekämmten Metriken für bestimmte Übereinstimmungen zu berechnen und auszudrucken.
Diese Einstellung ist bekannt als Mikrofon im TFM/VFM-Vokabular. Verfügbare Werte sind:
keine
Keine Zwangsberechnung.
pcn P/c/n-Berechnungen erzwingen.
pcnub
Erzwinge p/c/n/u/b-Berechnungen.
Standardwert ist keine.
cthresch
Dies ist der Schwellenwert für die Bereichskämmung, der für die Erkennung von gekämmten Frames verwendet wird. Dies im Wesentlichen
steuert, wie "stark" oder "sichtbar" Kämmen sein muss, um erkannt zu werden. Größere Werte bedeuten
Kämmen muss besser sichtbar sein und kleinere Werte bedeuten, dass Kämmen weniger sichtbar sein kann oder
stark und noch zu erkennen. Gültige Einstellungen sind von "-1" (jedes Pixel wird
als gekämmt erkannt) bis 255 (kein Pixel wird als gekämmt erkannt). Dies ist im Grunde ein
Pixeldifferenzwert. Ein guter Bereich ist "[8, 12]".
Der Standardwert ist 9.
Chroma
Legt fest, ob Chroma bei der Entscheidung für gekämmte Frames berücksichtigt wird oder nicht. Nur deaktivieren
Dies, wenn Ihre Quelle Chroma-Probleme (Regenbogen usw.) hat, die Probleme verursachen
für die gekämmte Frame-Erkennung mit aktiviertem Chroma. Eigentlich mit Chroma=0 is
normalerweise zuverlässiger, außer in dem Fall, in dem Chroma nur in der
Quelle.
Der Standardwert ist 0.
blockx
blocky
Stellen Sie die X-Achsen- und Y-Achsen-Größe des Fensters ein, das während des gekämmten Frames verwendet wird
Erkennung. Das hat mit der Größe des Gebietes zu tun, in dem komb Pixel sind
muss als gekämmt erkannt werden, damit ein Frame als gekämmt deklariert werden kann. Siehe die komb
Parameterbeschreibung für weitere Informationen. Mögliche Werte sind eine beliebige Zahl, die eine Potenz ist
von 2 beginnend bei 4 bis 512.
Der Standardwert ist 16.
komb
Die Anzahl der gekämmten Pixel in einem der blocky by blockx Größenblöcke auf dem
Rahmen für den Rahmen, der als gekämmt erkannt werden soll. Während cthresch steuert, wie "sichtbar" die
Kämmen muss sein, diese Einstellung steuert, "wie viel" Kämmen in jedem enthalten sein muss
lokalisierter Bereich (ein Fenster, das durch die blockx und blocky Einstellungen) am Rahmen.
Der Mindestwert ist 0 und der Höchstwert ist "blocky x blockx" (an diesem Punkt werden keine Frames mehr angezeigt)
jemals als gekämmt erkannt werden). Diese Einstellung ist bekannt als MI im TFM/VFM-Vokabular.
Der Standardwert ist 80.
p/c/n/u/b Bedeutung
p/c/n
Wir nehmen den folgenden telecined Stream an:
Obere Felder: 1 2 2 3 4
Untere Felder: 1 2 3 4 4
Die Zahlen entsprechen dem progressiven Frame, auf den sich die Felder beziehen. Hier die ersten beiden
Frames sind progressiv, der 3. und der 4. sind gekämmt und so weiter.
Wenn "fieldmatch" so konfiguriert ist, dass ein Matching von unten ausgeführt wird (Feld=Boden) das ist wie
dieser Eingabestrom wird transformiert:
Eingabestrom:
T 1 2 2 3 4
B 1 2 3 4 4 <-- passende Referenz
Übereinstimmungen: ccnnc
Ausgabestrom:
T 1 2 3 4 4
B 1 2 3 4 4
Als Ergebnis des Feldabgleichs können wir sehen, dass einige Frames dupliziert werden. Aufführen
ein komplettes inverses Telecine, müssen Sie sich nach diesem Vorgang auf einen Dezimationsfilter verlassen.
Siehe zum Beispiel die dezimieren Filter.
Dieselbe Operation passt jetzt von den oberen Feldern (Feld=Top) sieht aus wie das:
Eingabestrom:
T 1 2 2 3 4 <-- passende Referenz
B 1 2 3 4 4
Übereinstimmungen: ccppc
Ausgabestrom:
T 1 2 2 3 4
B 1 2 2 3 4
In diesen Beispielen können wir sehen, was p, c und n bedeuten; im Grunde beziehen sie sich auf den Rahmen und
Feld der entgegengesetzten Parität:
*<p stimmt mit dem Feld der entgegengesetzten Parität im vorherigen Frame überein>
*<c stimmt mit dem Feld der entgegengesetzten Parität im aktuellen Frame überein>
*<n stimmt mit dem Feld der entgegengesetzten Parität im nächsten Frame überein>
u/b
Die u und b Matching sind insofern etwas Besonderes, als sie aus dem Gegenteil zusammenpassen
Paritätsflagge. In den folgenden Beispielen gehen wir davon aus, dass wir derzeit den 2.
Rahmen (oben:2, unten:2). Je nach Übereinstimmung wird jeweils ein 'x' darüber und darunter platziert
übereinstimmende Felder.
Mit Bodenanpassung (Feld=Boden):
Übereinstimmung: cpnbu
xxxxx
Oben 1 2 2 1 2 2 1 2 2 1 2 2 1 2 2
Unten 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3
xxxxx
Ausgabeframes:
+2 (1)2 2 2 XNUMX XNUMX
+2 (2)2 1 3 XNUMX XNUMX
Mit Top-Matching (Feld=Top):
Übereinstimmung: cpnbu
xxxxx
Oben 1 2 2 1 2 2 1 2 2 1 2 2 1 2 2
Unten 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3
xxxxx
Ausgabeframes:
+2 (2)2 1 2 XNUMX XNUMX
+2 (1)3 2 2 XNUMX XNUMX
Beispiele
Einfache IVTC eines Top-Field-First-Telecined-Streams:
fieldmatch=order=tff:combmatch=none, dezimieren
Erweiterte IVTC, mit Fallback aktiviert jadif für noch gekämmte Rahmen:
fieldmatch=order=tff:combmatch=full, yadif=deint=interlaced, dezimieren
Feldreihenfolge
Transformieren Sie die Halbbildreihenfolge des Eingabevideos.
Es akzeptiert die folgenden Parameter:
Auftrag
Die Ausgabefeldreihenfolge. Gültige Werte sind tff für oberes Feld zuerst oder bff für unten
Feld zuerst.
Der Standardwert ist tff.
Die Transformation erfolgt durch Verschieben des Bildinhalts um eine Zeile nach oben oder unten, und
Füllen Sie die verbleibende Zeile mit entsprechendem Bildinhalt. Diese Methode ist konsistent
mit den meisten Broadcast-Halbbildreihenfolgewandlern.
Wenn das Eingangsvideo nicht als interlaced gekennzeichnet ist oder bereits als interlaced gekennzeichnet ist
der erforderlichen Ausgabefeldreihenfolge, dann verändert dieser Filter das eingehende Video nicht.
Es ist sehr nützlich, wenn Sie in oder aus PAL-DV-Material konvertieren, bei dem das untere Halbbild zuerst angezeigt wird.
Beispielsweise:
ffmpeg -i in.vob -vf "fieldorder=bff" out.dv
Fifo
Puffern Sie Eingabebilder und senden Sie sie, wenn sie angefordert werden.
Es ist hauptsächlich nützlich, wenn es vom libavfilter-Framework automatisch eingefügt wird.
Es braucht keine Parameter.
find_rect
Finde ein rechteckiges Objekt
Es akzeptiert die folgenden Optionen:
Objekt
Dateipfad des Objektbilds, muss in grau sein8.
Schwelle
Erkennungsschwelle, Standard ist 0.5.
Mipmaps
Anzahl der Mipmaps, Standard ist 3.
xmin, Ymin, xmax, ymax
Gibt das Rechteck an, in dem gesucht werden soll.
Beispiele
· Erstellen Sie eine repräsentative Palette eines bestimmten Videos mit ffmpeg:
ffmpeg -i file.ts -vf find_rect=newref.pgm,cover_rect=cover.jpg:mode=cover new.mkv
cover_rect
Bedecke ein rechteckiges Objekt
Es akzeptiert die folgenden Optionen:
Abdeckung
Der Dateipfad des optionalen Titelbilds muss in yuv420 sein.
Modus
Abdeckmodus einstellen.
Es akzeptiert die folgenden Werte:
Abdeckung
Bedecken Sie es mit dem mitgelieferten Bild
verwischen
decken Sie es ab, indem Sie die umgebenden Pixel interpolieren
Standardwert ist verwischen.
Beispiele
· Erstellen Sie eine repräsentative Palette eines bestimmten Videos mit ffmpeg:
ffmpeg -i file.ts -vf find_rect=newref.pgm,cover_rect=cover.jpg:mode=cover new.mkv
Format
Konvertieren Sie das Eingabevideo in eines der angegebenen Pixelformate. Libavfilter wird es versuchen
Wählen Sie eine aus, die als Eingabe für den nächsten Filter geeignet ist.
Es akzeptiert die folgenden Parameter:
pix_fmts
Eine durch '|' getrennte Liste von Pixelformatnamen, z. B. "pix_fmts=yuv420p|monow|rgb24".
Beispiele
· Konvertieren Sie das Eingangsvideo in das yuv420p Format
format=pix_fmts=yuv420p
Konvertieren Sie das Eingabevideo in eines der Formate in der Liste
format=pix_fmts=yuv420p|yuv444p|yuv410p
fps
Konvertieren Sie das Video in eine angegebene konstante Bildrate, indem Sie Bilder duplizieren oder fallen lassen
notwendig.
Es akzeptiert die folgenden Parameter:
fps Die gewünschte Ausgabe-Framerate. Der Standardwert ist 25.
rund
Rundungsmethode.
Mögliche Werte sind:
Null
Nullrunde in Richtung 0
inf Runde weg von 0
nach unten
rund in Richtung -unendlich
up rund gegen +unendlich
in der Nähe von
Runde zum nächsten
Die Vorgabe ist "nahe".
Startzeit
Angenommen, der erste PTS sollte den angegebenen Wert in Sekunden haben. Dies ermöglicht
Auffüllen/Trimmen am Anfang des Streams. Standardmäßig wird keine Annahme über die
erwarteten PTS des ersten Frames, daher wird kein Auffüllen oder Trimmen durchgeführt. Zum Beispiel das
könnte auf 0 gesetzt werden, um den Anfang mit Duplikaten des ersten Frames aufzufüllen, wenn ein Video
stream beginnt nach dem Audiostream oder um Frames mit negativem PTS zu trimmen.
Alternativ können die Optionen als Flatstring angegeben werden: fps[:rund].
Siehe auch die Einstellungen Filter.
Beispiele
· Eine typische Verwendung, um die fps auf 25 einzustellen:
fps=fps=25
· Setzt die fps auf 24, wobei Abkürzung und Rundungsmethode verwendet werden, um auf das nächste zu runden:
fps=fps=film:round=nah
Rahmenpaket
Packen Sie zwei verschiedene Videostreams in ein stereoskopisches Video und setzen Sie die richtigen Metadaten auf
unterstützte Codecs. Die beiden Ansichten sollten die gleiche Größe und Bildrate und Verarbeitung haben
stoppt, wenn das kürzere Video endet. Bitte beachten Sie, dass Sie die Ansicht bequem anpassen können
Eigenschaften mit dem Treppe und fps Filter.
Es akzeptiert die folgenden Parameter:
Format
Das gewünschte Verpackungsformat. Unterstützte Werte sind:
Sbs Die Ansichten sind nebeneinander (Standard).
Tab Die Ansichten liegen übereinander.
Linien
Die Ansichten sind zeilenweise verpackt.
Spalten
Die Ansichten sind spaltenweise gepackt.
Frameseq
Die Ansichten sind zeitlich verschachtelt.
Einige Beispiele:
# Konvertieren Sie die linke und rechte Ansicht in ein bildsequenzielles Video
ffmpeg -i LINKS -i RECHTS -filter_complex framepack=frameseq AUSGABE
# Konvertieren Sie Ansichten in ein Side-by-Side-Video mit derselben Ausgabeauflösung wie die Eingabe
ffmpeg -i LEFT -i RIGHT -filter_complex [0:v]scale=w=iw/2[left],[1:v]scale=w=iw/2[right],[left][right]framepack=sbs AUSGANG
Framerate
Ändern Sie die Bildrate, indem Sie neue Videoausgabebilder aus den Quellbildern interpolieren.
Dieser Filter ist nicht dafür ausgelegt, mit Interlaced-Medien richtig zu funktionieren. Wenn du es wünschst
Ändern Sie die Bildrate von Interlaced-Medien, dann müssen Sie vorher deinterlacen
filtern und nach diesem Filter erneut verschachteln.
Eine Beschreibung der akzeptierten Optionen folgt.
fps Geben Sie die Ausgabe-Frames pro Sekunde an. Diese Option kann auch als Wert angegeben werden
allein. Der Standardwert ist 50.
interp_start
Geben Sie den Anfang eines Bereichs an, in dem der Ausgaberahmen als linear erstellt wird
Interpolation von zwei Frames. Der Bereich ist [0-255], der Standardwert ist 15.
interp_end
Geben Sie das Ende eines Bereichs an, in dem der Ausgaberahmen als linear erstellt wird
Interpolation von zwei Frames. Der Bereich ist [0-255], der Standardwert ist 240.
Szene
Legen Sie die Stufe fest, bei der ein Szenenwechsel erkannt wird, als Wert zwischen 0 und 100 bis
eine neue Szene angeben; ein niedriger Wert spiegelt eine geringe Wahrscheinlichkeit wider, dass der aktuelle Frame
eine neue Szene einführen, während ein höherer Wert bedeutet, dass das aktuelle Bild mit größerer Wahrscheinlichkeit
eins sein. Der Standardwert ist 7.
Fahnen
Legen Sie Flags fest, die den Filterprozess beeinflussen.
Verfügbarer Wert für Fahnen ist:
Scene_change_detect, scd
Aktivieren Sie die Szenenwechselerkennung mit dem Wert der Option Szene. Diese Flagge ist
standardmäßig aktiviert.
Rahmenschritt
Wählen Sie jeden N-ten Frame einen Frame aus.
Dieser Filter akzeptiert die folgende Option:
Step
Wählen Sie den Rahmen nach jedem "Schritt"-Rahmen aus. Zulässige Werte sind positive ganze Zahlen höher
als 0. Der Standardwert ist 1.
frei0r
Wenden Sie einen frei0r-Effekt auf das Eingangsvideo an.
Um die Kompilierung dieses Filters zu ermöglichen, müssen Sie den frei0r-Header installieren und
FFmpeg mit "--enable-frei0r" konfigurieren.
Es akzeptiert die folgenden Parameter:
Filtername
Der Name des zu ladenden frei0r-Effekts. Wenn die Umgebungsvariable FREI0R_PFAD is
definiert, wird der frei0r-Effekt in jedem der Verzeichnisse gesucht, die durch die
durch Doppelpunkte getrennte Liste in FREIOR_PFAD. Ansonsten sind die Standard-Frei0r-Pfade
gesucht, in dieser Reihenfolge: HOME/.frei0r-1/lib/, /usr/local/lib/frei0r-1/,
/usr/lib/frei0r-1/.
filter_params
Eine durch '|' getrennte Liste von Parametern, die an den frei0r-Effekt übergeben werden.
Ein frei0r-Effektparameter kann ein boolescher Wert sein (sein Wert ist entweder "y" oder "n"), ein Double, a
Farbe (angegeben als R/G/B, Wobei R, G und B sind Gleitkommazahlen zwischen 0.0 und
1.0, einschließlich) oder durch eine Farbbeschreibung, die im Abschnitt "Farbe" in der ffmpeg-
utils manual), eine Position (angegeben als X/Y, Wobei X und Y sind Gleitkommazahlen)
und/oder eine Schnur.
Anzahl und Typen der Parameter hängen vom geladenen Effekt ab. Ist ein Effektparameter
nicht angegeben, wird der Standardwert gesetzt.
Beispiele
· Wenden Sie den Distortion0r-Effekt an, indem Sie die ersten beiden Doppelparameter einstellen:
frei0r=filter_name=distort0r:filter_params=0.5|0.01
· Wenden Sie den colordistance-Effekt an und nehmen Sie eine Farbe als ersten Parameter:
frei0r=Farbabstand:0.2/0.3/0.4
frei0r=Farbabstand:violett
frei0r=Farbabstand:0x112233
· Wenden Sie den perspektivischen Effekt an, indem Sie die Bildpositionen oben links und oben rechts angeben:
frei0r=perspective:0.2/0.2|0.8/0.2
Weitere Informationen finden Sie unterhttp://frei0r.dyne.org>
fspp
Wenden Sie eine schnelle und einfache Nachbearbeitung an. Es ist eine schnellere Version von spp.
Es teilt (I)DCT in horizontale/vertikale Durchgänge auf. Im Gegensatz zur einfachen Nachbearbeitung
Filter, einer von ihnen wird einmal pro Block ausgeführt, nicht pro Pixel. Das ermöglicht viel
höhere Geschwindigkeit.
Der Filter akzeptiert die folgenden Optionen:
qualitativ hochwertiges
Qualität einstellen. Diese Option definiert die Anzahl der Ebenen für die Mittelwertbildung. Es akzeptiert ein
Ganzzahl im Bereich 4-5. Der Standardwert ist 4.
qp Erzwinge einen konstanten Quantisierungsparameter. Es akzeptiert eine ganze Zahl im Bereich von 0-63. Wenn nicht
eingestellt, verwendet der Filter die QP aus dem Videostream (sofern verfügbar).
Stärke
Filterstärke einstellen. Es akzeptiert eine ganze Zahl im Bereich von -15 bis 32. Niedrigere Werte bedeuten mehr
Details, aber auch mehr Artefakte, während höhere Werte das Bild glatter machen, aber auch
verschwommener. Der Standardwert ist 0 X PSNR optimal.
use_bframe_qp
Aktivieren Sie die Verwendung des QP von den B-Frames, wenn auf 1 gesetzt. Die Verwendung dieser Option kann zu
flackern, da die B-Frames oft größere QP haben. Der Standardwert ist 0 (nicht aktiviert).
geq
Der Filter akzeptiert die folgenden Optionen:
lum_expr, lum
Stellen Sie den Luminanz-Ausdruck ein.
cb_expr, cb
Stellen Sie den Chrominanz-Blau-Ausdruck ein.
cr_expr, cr
Stellen Sie den Chrominanz-Rot-Ausdruck ein.
alpha_Ausdruck, a
Legen Sie den Alpha-Ausdruck fest.
roter_ausdruck, r
Stellen Sie den roten Ausdruck ein.
grün_ausdruck, g
Legen Sie den grünen Ausdruck fest.
blauer_ausdruck, b
Legen Sie den blauen Ausdruck fest.
Der Farbraum wird gemäß den angegebenen Optionen ausgewählt. Wenn einer der lum_expr,
cb_expr, oder auch cr_expr Optionen angegeben ist, wählt der Filter automatisch ein YCbCr
Farbraum. Wenn einer der red_expr, grüner Ausdruck, oder auch blue_expr Optionen angegeben ist, wird es
Wählen Sie einen RGB-Farbraum aus.
Wenn einer der Chrominanzausdrücke nicht definiert ist, wird auf den anderen zurückgegriffen. Wenn nein
Alpha-Ausdruck angegeben ist, wird er als undurchsichtiger Wert ausgewertet. Wenn keine Chrominanz
Ausdrücke angegeben sind, werden sie zum Luminanzausdruck ausgewertet.
Die Ausdrücke können die folgenden Variablen und Funktionen verwenden:
N Die fortlaufende Nummer des gefilterten Frames, beginnend bei 0.
X
Y Die Koordinaten des aktuellen Samples.
W
H Die Breite und Höhe des Bildes.
SW
SH Breiten- und Höhenskalierung abhängig von der aktuell gefilterten Ebene. Es ist das Verhältnis
zwischen der entsprechenden Anzahl von Pixeln der Luma-Ebene und den Pixeln der aktuellen Ebene. Z.B
für YUV4:2:0 sind die Werte „1,1“ für die Luma-Ebene und „0.5,0.5“ für die Chroma-Ebene.
T Zeit des aktuellen Frames, ausgedrückt in Sekunden.
p(x, y)
Gibt den Wert des Pixels an Position (x,y) des aktuellen Flugzeugs.
Lum(x, y)
Gibt den Wert des Pixels an Position (x,y) der Luminanzebene.
cb(x, y)
Gibt den Wert des Pixels an Position (x,y) der Blaudifferenz-Chroma-Ebene.
Geben Sie 0 zurück, wenn es keine solche Ebene gibt.
cr(x, y)
Gibt den Wert des Pixels an Position (x,y) der Rotdifferenz-Chroma-Ebene.
Geben Sie 0 zurück, wenn es keine solche Ebene gibt.
r(x, y)
g(x, y)
b(x, y)
Gibt den Wert des Pixels an Position (x,y) der Rot/Grün/Blau-Komponente.
Geben Sie 0 zurück, wenn es keine solche Komponente gibt.
alpha(x, y)
Gibt den Wert des Pixels an Position (x,y) der Alphaebene. Gib 0 zurück, falls vorhanden
ist kein solches Flugzeug.
Für Funktionen, wenn x und y außerhalb des Bereichs liegen, wird der Wert automatisch beschnitten
die nähere Kante.
Beispiele
· Spiegeln Sie das Bild horizontal:
geq=p(WX\,Y)
· Erzeuge eine zweidimensionale Sinuswelle mit dem Winkel "PI/3" und einer Wellenlänge von 100 Pixeln:
geq=128 + 100*sin(2*(PI/100)*(cos(PI/3)*(X-50*T) + sin(PI/3)*Y)):128:128
· Generieren Sie ein schickes, rätselhaftes Moving Light:
nullsrc=s=256x256,geq=zufällig(1)/hypot(X-cos(N*0.07)*W/2-W/2\,Y-sin(N*0.09)*H/2-H/2)^2*1000000*sin(N*0.02):128:128
· Erzeuge einen schnellen Prägeeffekt:
format=grau,geq=lum_expr='(p(X,Y)+(256-p(X-4,Y-4)))/2'
· RGB-Komponenten je nach Pixelposition ändern:
geq=r='X/W*r(X,Y)':g='(1-X/W)*g(X,Y)':b='(HY)/H*b(X,Y )'
· Erstellen Sie einen radialen Farbverlauf, der die gleiche Größe wie die Eingabe hat (siehe auch die Vignette
Filter):
geq=lum=255*gauss((X/W-0.5)*3)*gauss((Y/H-0.5)*3)/gauss(0) /gauss(0),format=grau
· Erstellen Sie einen linearen Farbverlauf, um ihn als Maske für einen anderen Filter zu verwenden, und komponieren Sie dann mit
Auflage. In diesem Beispiel wird das Video von oben nach unten allmählich verschwommener
der untere Teil der y-Achse, wie durch den linearen Gradienten definiert:
ffmpeg -i input.mp4 -filter_complex "geq=lum=255*(Y/H),format=gray[grad];[0:v]boxblur=4[blur];[blur][grad]alphamerge[alpha] ;[0:v][alpha]Overlay" Ausgabe.mp4
Spaß
Beheben Sie die Banding-Artefakte, die manchmal in fast flache Regionen eingeführt werden, indem Sie
Kürzung auf 8bit Farbtiefe. Interpolieren Sie die Gradienten, die dorthin gehen sollen, wo die Bänder
sind, und zittern sie.
Es ist nur für die Wiedergabe gedacht. Verwenden Sie es nicht vor der verlustbehafteten Komprimierung, da
Kompression neigt dazu, das Zittern zu verlieren und die Bänder zurückzubringen.
Es akzeptiert die folgenden Parameter:
Stärke
Der maximale Betrag, um den der Filter ein Pixel ändert. Das ist auch der
Schwellenwert für die Erkennung nahezu flacher Regionen. Zulässige Werte reichen von 51 bis 64;
der Standardwert ist 1.2. Außerhalb des Bereichs liegende Werte werden auf den gültigen Bereich beschnitten.
radius
Die Nachbarschaft, an die der Farbverlauf angepasst werden soll. Ein größerer Radius sorgt für sanftere Steigungen,
verhindert aber auch, dass der Filter die Pixel in der Nähe detaillierter Regionen ändert.
Zulässige Werte sind 8-32; der Standardwert ist 16. Außerhalb des Bereichs liegende Werte sind
auf den gültigen Bereich abgeschnitten.
Alternativ können die Optionen als Flatstring angegeben werden: Stärke[:radius]
Beispiele
· Wenden Sie den Filter mit einer Stärke von 3.5 und einem Radius von 8 an:
gradfun=3.5:8
· Radius angeben, ohne die Stärke (die auf den Standardwert zurückfällt):
gradfun=radius=8
halsklaue
Wenden Sie eine Hald CLUT auf einen Videostream an.
Der erste Eingang ist der zu verarbeitende Videostream und der zweite die Hald CLUT. Der Hald
Die CLUT-Eingabe kann ein einfaches Bild oder ein vollständiger Videostream sein.
Der Filter akzeptiert die folgenden Optionen:
kürzeste
Beendigung erzwingen, wenn die kürzeste Eingabe beendet wird. Standard ist 0.
wiederholen
Wenden Sie die letzte CLUT nach dem Ende des Streams weiter an. Ein Wert von 0 deaktiviert die
Filter, nachdem der letzte Frame der CLUT erreicht ist. Standard ist 1.
"haldclut" hat auch die gleichen Interpolationsmöglichkeiten wie lut3d (beide Filter haben das gleiche gemeinsam
Einbauten).
Weitere Informationen zum Hald CLUT finden Sie auf der Website von Eskil Steenberg (Hald CLUT
Autor) beihttp://www.quelsolaar.com/technology/clut.html>.
Arbeitsablauf Beispiele
Hald CLUT-Videostream
Generieren Sie einen Identitäts-Hald-CLUT-Stream, der mit verschiedenen Effekten geändert wurde:
ffmpeg -f lavfi -i B =8 -vf "hue=H=2*PI*t:s=sin(2*PI*t)+1, curves=cross_process" -t 10 -c:v ffv1 clut.nut
Hinweis: Stellen Sie sicher, dass Sie einen verlustfreien Codec verwenden.
Verwenden Sie es dann mit "haldclut", um es auf einen zufälligen Stream anzuwenden:
ffmpeg -f lavfi -i mandelbrot -i clut.nut -filter_complex '[0][1] haldclut' -t 20 mandelclut.mkv
Die Hald CLUT wird auf die ersten 10 Sekunden angewendet (Dauer von Klumpennuss), dann ist die
Das neueste Bild dieses CLUT-Streams wird auf die verbleibenden Frames des
"mandelbrot"-Stream.
Halbe CLUT mit Vorschau
Eine Hald CLUT soll ein quadratisches Bild von "Level*Level*Level" von . sein
"Level*Level*Level"-Pixel. Für eine gegebene Hald CLUT wählt FFmpeg die größtmögliche aus
Quadrat, das oben links im Bild beginnt. Die verbleibenden Füllpixel (unten oder
rechts) werden ignoriert. Dieser Bereich kann verwendet werden, um eine Vorschau der Hald CLUT hinzuzufügen.
Normalerweise wird die folgende generierte Hald-CLUT vom "haldclut"-Filter unterstützt:
ffmpeg -f lavfi -i B =8 -vf"
pad=iw+320 [padded_clut];
smptebars=s=320x256, teilen [a][b];
[padded_clut][a] overlay=W-320:h, Curves=color_negative [main];
[main][b] overlay=W-320" -frames:v 1 clut.png
Es enthält das Original und eine Vorschau der Wirkung der CLUT: SMPTE-Farbbalken sind
rechts oben und unten die gleichen Farbbalken angezeigt, die von den Farbänderungen verarbeitet werden.
Dann kann die Wirkung dieser Hald CLUT visualisiert werden mit:
ffplay input.mkv -vf "movie=clut.png, [in] haldclut"
hflipp
Spiegeln Sie das Eingangsvideo horizontal.
Um beispielsweise das Eingangsvideo horizontal zu spiegeln mit ffmpeg:
ffmpeg -i in.avi -vf "hflip" out.avi
histeq
Dieser Filter wendet eine globale Farbhistogramm-Entzerrung auf Einzelbildbasis an.
Es kann verwendet werden, um Videos zu korrigieren, die einen komprimierten Bereich von Pixelintensitäten aufweisen. Der
Filter verteilt die Pixelintensitäten neu, um ihre Verteilung über die
Intensitätsbereich. Es kann als "automatisch anpassender Kontrastfilter" angesehen werden. Dies
Filter ist nur zum Korrigieren von verschlechtertem oder schlecht aufgenommenem Quellvideo nützlich.
Der Filter akzeptiert die folgenden Optionen:
Stärke
Bestimmen Sie den anzuwendenden Ausgleichsbetrag. Wenn die Festigkeit verringert wird,
Die Verteilung der Pixelintensitäten nähert sich immer mehr der des Eingabebildes an.
Der Wert muss eine Gleitkommazahl im Bereich [0,1] sein und ist standardmäßig 0.200.
Intensität
Stellen Sie die maximal erzeugbare Intensität ein und skalieren Sie die Ausgabewerte
passend. Die Stärke sollte wie gewünscht eingestellt werden und dann kann die Intensität eingestellt werden
begrenzt, falls erforderlich, um ein Auswaschen zu vermeiden. Der Wert muss eine Gleitkommazahl im Bereich . sein
[0,1] und standardmäßig auf 0.210 eingestellt.
anti Banding
Stellen Sie die Antibanding-Stufe ein. Wenn aktiviert, variiert der Filter zufällig die Luminanz von
Ausgabepixel um einen kleinen Betrag, um eine Streifenbildung des Histogramms zu vermeiden. Mögliche Werte sind
"keine", "schwach" oder "stark". Standardmäßig ist "keine" eingestellt.
Histogramm
Berechnen und zeichnen Sie ein Farbverteilungshistogramm für das Eingabevideo.
Das berechnete Histogramm ist eine Darstellung der Farbkomponentenverteilung in an
Bild.
Der Filter akzeptiert die folgenden Optionen:
Modus
Histogrammmodus einstellen.
Es akzeptiert die folgenden Werte:
Level
Standardhistogramm, das die Verteilung der Farbkomponenten in einem Bild anzeigt.
Zeigt ein Farbdiagramm für jede Farbkomponente an. Zeigt die Verteilung der Y, U, V,
A- oder R-, G-, B-Komponenten, je nach Eingabeformat, im aktuellen Frame. Unter
In jedem Diagramm wird ein Farbkomponentenskalenmesser angezeigt.
Farbe
Zeigt Chroma-Werte (U/V-Farbplatzierung) in einem zweidimensionalen Diagramm an (das ist
Vektorskop genannt). Je heller ein Pixel im Vektorskop, desto mehr Pixel von
der Eingaberahmen entspricht diesem Pixel (dh mehr Pixel haben diese Farbsättigung)
Wert). Die V-Komponente wird auf der horizontalen (X)-Achse angezeigt, wobei ganz links
Seite ist V = 0 und die ganz rechte Seite ist V = 255. Die U-Komponente ist
angezeigt auf der vertikalen (Y) Achse, wobei das obere U = 0 darstellt und das untere
repräsentiert U = 255.
Die Position eines weißen Pixels im Graphen entspricht dem Chroma-Wert von a
Pixel des Eingabeclips. Die Grafik kann daher verwendet werden, um den Farbton (Farbe
Geschmack) und die Sättigung (die Dominanz des Farbtons in der Farbe). Als der Farbton von
eine Farbe ändert sich, sie bewegt sich um das Quadrat. In der Mitte des Platzes die
die Sättigung ist null, was bedeutet, dass das entsprechende Pixel keine Farbe hat. Wenn die
Menge einer bestimmten Farbe wird erhöht (während die anderen Farben unverändert bleiben)
die Sättigung nimmt zu und der Indikator bewegt sich zum Rand des Quadrats.
color2
Chroma-Werte im Vektorskop, ähnlich wie "Farbe", aber die tatsächlichen Chroma-Werte sind
angezeigt.
Wellenform
Farbkomponentendiagramm pro Zeile/Spalte. Im Zeilenmodus die Grafik auf der linken Seite
repräsentiert den Farbkomponentenwert 0 und die rechte Seite repräsentiert den Wert = 255. In
Spaltenmodus, die obere Seite repräsentiert den Farbkomponentenwert = 0 und die untere Seite
stellt Wert = 255 dar.
Der Standardwert ist "Stufen".
Ebene_Höhe
Stellen Sie die Höhe der Ebene in "Ebenen" ein. Der Standardwert ist 200. Der zulässige Bereich ist [50, 2048].
scale_height
Stellen Sie die Höhe der Farbskala in "Stufen" ein. Der Standardwert ist 12. Zulässiger Bereich ist [0, 40].
Step
Schritt für "Wellenform"-Modus einstellen. Kleinere Werte sind nützlich, um herauszufinden, wie viele Werte von
die gleiche Luminanz wird über die Eingabezeilen/-spalten verteilt. Der Standardwert ist 10.
Zulässiger Bereich ist [1, 255].
Wellenform_Modus
Modus für "Wellenform" einstellen. Kann entweder "Zeile" oder "Spalte" sein. Standard ist "Reihe".
wave_mirror
Spiegelungsmodus für "Wellenform" einstellen. 0 bedeutet ungespiegelt, 1 bedeutet gespiegelt. In gespiegelt
Modus, höhere Werte werden auf der linken Seite für den "Reihen"-Modus und oben dargestellt
für den "Spalten"-Modus. Der Standardwert ist 0 (nicht gespiegelt).
Anzeigemodus
Anzeigemodus für "Wellenform" und "Stufen" einstellen. Es akzeptiert die folgenden Werte:
Parade
Zeigen Sie eine separate Grafik für die Farbkomponenten nebeneinander in der Wellenform "Reihe" an
Modus oder untereinander im Wellenformmodus "Spalte" für "Wellenform"-Histogramm
Modus. Für den Histogrammmodus "Stufen" werden Diagramme pro Farbkomponente darunter platziert
den Umgang miteinander.
Die Verwendung dieses Anzeigemodus im Histogrammmodus "Wellenform" erleichtert das Erkennen von Farben
wirft die Lichter und Schatten eines Bildes ein, indem die Konturen der
oberen und unteren Diagramme jeder Wellenform. Da Weiß, Grau und Schwarz
gekennzeichnet durch genau gleiche Mengen an Rot, Grün und Blau, neutrale Bereiche von
das Bild sollte drei Wellenformen von ungefähr gleicher Breite/Höhe anzeigen. Wenn nicht,
Die Korrektur ist einfach durchzuführen, indem die Pegel der drei Wellenformen angepasst werden.
Auflage
Präsentiert Informationen, die mit denen in der "Parade" identisch sind, außer dass die Grafiken
darstellende Farbkomponenten werden direkt überlagert.
Dieser Anzeigemodus im Histogrammmodus "Wellenform" erleichtert das Erkennen von relativen
Unterschiede oder Ähnlichkeiten in überlappenden Bereichen der Farbkomponenten, die
identisch sein sollen, wie neutrales Weiß, Grau oder Schwarz.
Standard ist "Parade".
level_mode
Modus für "Ebenen" einstellen. Kann entweder "linear" oder "logarithmisch" sein. Standard ist "linear".
Komponenten
Legen Sie fest, welche Farbkomponenten für den Modus "Stufen" angezeigt werden sollen. Standard ist 7.
Beispiele
· Histogramm berechnen und zeichnen:
ffplay -i input -vf Histogramm
hqdn3d
Dies ist ein hochpräziser/qualitativer 3D-Entrauschungsfilter. Es zielt darauf ab, Bildrauschen zu reduzieren,
Erzeugen Sie glatte Bilder und machen Sie Standbilder wirklich still. Es sollte verbessern
Kompressibilität.
Es akzeptiert die folgenden optionalen Parameter:
luma_räumlich
Eine nicht negative Gleitkommazahl, die die räumliche Luminanzstärke angibt. Es
standardmäßig auf 4.0.
chroma_räumlich
Eine nicht negative Gleitkommazahl, die die räumliche Farbstärke angibt. Es
standardmäßig auf 3.0*luma_räumlich/ 4.0.
luma_tmp
Eine Gleitkommazahl, die die zeitliche Luma-Stärke angibt. Es ist standardmäßig
6.0 *luma_räumlich/ 4.0.
chroma_tmp
Eine Gleitkommazahl, die die zeitliche Stärke der Chroma angibt. Es ist standardmäßig
luma_tmp*chroma_räumlich/luma_räumlich.
hqx
Wenden Sie einen hochwertigen Vergrößerungsfilter an, der für Pixelkunst entwickelt wurde. Dieser Filter war
ursprünglich von Maxim Stepin erstellt.
Es akzeptiert die folgende Option:
n Stellen Sie das Skalierungsmaß ein: 2 für „hq2x“, 3 für „hq3x“ und 4 für „hq4x“. Standard ist 3.
Stapel
Stapeln Sie Eingabevideos horizontal.
Alle Streams müssen dasselbe Pixelformat und dieselbe Höhe aufweisen.
Beachten Sie, dass dieser Filter schneller ist als die Verwendung von Auflage und Unterlage filtern, um dieselbe Ausgabe zu erstellen.
Der Filter akzeptiert die folgende Option:
nb_eingaben
Legen Sie die Anzahl der Eingabestreams fest. Standard ist 2.
Farbton
Ändern Sie den Farbton und/oder die Sättigung der Eingabe.
Es akzeptiert die folgenden Parameter:
h Geben Sie den Farbtonwinkel in Grad an. Es akzeptiert einen Ausdruck und Standardwerte
auf "0".
s Geben Sie die Sättigung im Bereich [-10,10] an. Es akzeptiert einen Ausdruck und ist standardmäßig auf
"1".
H Geben Sie den Farbtonwinkel als eine Anzahl von Bogenmaßen an. Es akzeptiert einen Ausdruck und Standardwerte
auf "0".
b Geben Sie die Helligkeit im Bereich [-10,10] an. Es akzeptiert einen Ausdruck und ist standardmäßig auf
"0".
h und H schließen sich gegenseitig aus und können nicht gleichzeitig angegeben werden.
Die b, h, H und s Optionswerte sind Ausdrücke, die die folgenden Konstanten enthalten:
n Frameanzahl des Eingabeframes beginnend bei 0
pts Präsentationszeitstempel des Eingaberahmens, ausgedrückt in Zeitbasiseinheiten
r Bildrate des Eingangsvideos, NAN, wenn die Eingangsbildrate unbekannt ist
t Zeitstempel in Sekunden ausgedrückt, NAN, wenn der Eingabezeitstempel unbekannt ist
tb Zeitbasis des Eingangsvideos
Beispiele
· Stellen Sie den Farbton auf 90 Grad und die Sättigung auf 1.0 ein:
Farbton=h=90:s=1
· Gleicher Befehl, aber mit Angabe des Farbtons im Bogenmaß:
Farbton=H=PI/2:s=1
· Rotieren Sie den Farbton und lassen Sie die Sättigung über einen Zeitraum von 0 Sekunde zwischen 2 und 1 schwanken:
hue="H=2*PI*t: s=sin(2*PI*t)+1"
· Wenden Sie einen 3-Sekunden-Sättigungs-Einblendeffekt beginnend bei 0 an:
hue="s=min(t/3\,1)"
Der allgemeine Einblendungsausdruck kann wie folgt geschrieben werden:
hue="s=min(0\, max((t-START)/DAUER\, 1))"
· Wenden Sie einen 3-Sekunden-Sättigungs-Ausblendeffekt an, der bei 5 Sekunden beginnt:
hue="s=max(0\, min(1\, (8-t)/3))"
Der allgemeine Ausblendungsausdruck kann wie folgt geschrieben werden:
hue="s=max(0\, min(1\, (START+DAUER-t)/DAUER))"
Befehle
Dieser Filter unterstützt die folgenden Befehle:
b
s
h
H Ändern Sie den Farbton und/oder die Sättigung und/oder Helligkeit des Eingangsvideos. Der
Befehl akzeptiert dieselbe Syntax wie die entsprechende Option.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
idee
Video-Interlacing-Typ erkennen.
Dieser Filter versucht zu erkennen, ob die eingegebenen Frames interlaced, progressiv, oben oder unten sind
Feld zuerst. Es wird auch versuchen, Felder zu erkennen, die sich zwischen benachbarten Bildern wiederholen
(ein Zeichen von Telecine).
Die Einzelbilderkennung berücksichtigt bei der Klassifizierung nur unmittelbar benachbarte Bilder
Rahmen. Die Mehrfach-Frame-Erkennung beinhaltet die Klassifizierungshistorie der vorherigen
Frames.
Der Filter protokolliert diese Metadatenwerte:
single.current_frame
Erkannter Typ des aktuellen Frames mit Einzelframe-Erkennung. Einer von: ``tff'' (top
Feld zuerst), ``bff'' (unteres Feld zuerst), ``progressiv'' oder ``unbestimmt''
single.tff
Kumulative Anzahl von Frames, die bei der Einzelbild-Erkennung zuerst als oberstes Halbbild erkannt wurden.
multiple.tff
Kumulative Anzahl von Frames, die zuerst als oberstes Halbbild erkannt wurden, wenn mehrere Frames verwendet werden
Erkennung.
Single.bff
Kumulative Anzahl von Frames, die zuerst als unteres Halbbild erkannt wurden, wenn Einzelbild verwendet wird
Erkennung.
multiple.current_frame
Erkannter Typ des aktuellen Frames mithilfe der Mehrfach-Frame-Erkennung. Einer von: ``tff'' (oben
Feld zuerst), ``bff'' (unteres Feld zuerst), ``progressiv'' oder ``unbestimmt''
mehrere.bff
Kumulative Anzahl von Frames, die bei Verwendung mehrerer Frames zuerst als unteres Halbbild erkannt wurden
Erkennung.
einzeln.progressiv
Kumulative Anzahl von Frames, die mithilfe der Einzelbilderkennung als progressiv erkannt wurden.
mehrfach.progressiv
Kumulative Anzahl von Frames, die mithilfe der Mehrfach-Frame-Erkennung als progressiv erkannt wurden.
single.unbestimmt
Kumulative Anzahl von Frames, die mit der Einzelbilderkennung nicht klassifiziert werden konnten.
mehrfach.unbestimmt
Kumulative Anzahl von Frames, die nicht mit mehreren Frames klassifiziert werden konnten
Erkennung.
wiederholter.aktueller_frame
Welches Feld im aktuellen Frame wird ab dem letzten wiederholt. Einer von ``weder'',
``oben'' oder ``unten''.
wiederholt.weder
Kumulative Anzahl von Frames ohne wiederholtes Halbbild.
wiederholt.top
Kumulative Anzahl von Frames, wobei das obere Halbbild von der Spitze des vorherigen Frames wiederholt wird
Feld.
wiederholt.unten
Kumulative Anzahl von Frames, wobei das untere Halbbild aus den vorherigen Frames wiederholt wird
unteres Feld.
Der Filter akzeptiert die folgenden Optionen:
intl_thres
Interlacing-Schwellenwert einstellen.
prog_thres
Stellen Sie den progressiven Schwellenwert ein.
wiederholen_thres
Schwellenwert für die wiederholte Felderkennung.
Halbwertszeit
Anzahl der Frames, nach denen der Beitrag eines bestimmten Frames zur Statistik halbiert wird
(dh es trägt nur 0.5 zu seiner Klassifizierung bei). Der Standardwert von 0 bedeutet, dass
alle gesehenen Frames erhalten für immer das volle Gewicht von 1.0.
analysis_interlaced_flag
Wenn dieser nicht 0 ist, verwendet idet die angegebene Anzahl von Frames, um zu bestimmen, ob
das Interlaced-Flag genau ist, zählt es keine unbestimmten Frames. Wenn die Flagge
als richtig befunden wird, wird es ohne weitere Berechnungen verwendet, wenn es
als ungenau befunden, wird es ohne weitere Berechnungen gelöscht. Dies
ermöglicht das Einfügen des Idet-Filters als rechnerische Methode zur Bereinigung der
verflochtene Flagge
il
Felder entschachteln oder verschachteln.
Mit diesem Filter können Halbbilder von Bildern mit Zeilensprung verarbeitet werden, ohne sie zu deinterlacen.
Deinterleaving teilt das Eingabebild in 2 Halbbilder (sog. Halbbilder). Ungerade Linien
werden in die obere Hälfte des Ausgabebildes verschoben, gerade Linien in die untere Hälfte. Sie können
verarbeiten (filtern) Sie sie unabhängig voneinander und verschachteln Sie sie dann erneut.
Der Filter akzeptiert die folgenden Optionen:
luma_mode, l
chroma_mode, c
alpha_modus, a
Verfügbare Werte für luma_mode, chroma_mode und alpha_modus sind:
keine
Nichts tun.
entschachteln, d
Felder entschachteln und übereinander platzieren.
verschachteln, i
Felder verschachteln. Kehren Sie den Deinterleaving-Effekt um.
Der Standardwert ist "keiner".
luma_swap, ls
chroma_swap, cs
alpha_swap, as
Luma/Chroma/Alpha-Felder tauschen. Tauschen Sie gerade und ungerade Zeilen aus. Der Standardwert ist 0.
aufblasen
Wenden Sie den Aufblaseffekt auf das Video an.
Dieser Filter ersetzt das Pixel durch das aus einer regionalen(3x3) Durchschnitt nur unter Berücksichtigung
Werte höher als das Pixel.
Es akzeptiert die folgenden Optionen:
Schwelle0
Schwelle1
Schwelle2
Schwelle3
Begrenzen Sie die maximale Änderung für jede Ebene, der Standardwert ist 65535. Bei 0 bleibt die Ebene bestehen
unverändert.
verschachteln
Einfacher Interlacing-Filter aus progressiven Inhalten. Dies verschachtelt obere (oder untere)
Zeilen aus ungeraden Frames mit unteren (oder oberen) Zeilen aus geraden Frames, Halbierung der Framerate
und Beibehaltung der Bildhöhe.
Original Original neuer Rahmen
Rahmen 'j' Rahmen 'j+1' (tff)
========== =========== ==================
Zeile 0 ------------------> Rahmen 'j' Zeile 0
Zeile 1 Zeile 1 ----> Rahmen 'j+1' Zeile 1
Zeile 2 ---------------------------------- Rahmen 'j' Zeile 2
Zeile 3 Zeile 3 ----> Rahmen 'j+1' Zeile 3
... ... ...
Neuer Frame + 1 wird von Frame 'j+2' und Frame 'j+3' generiert und so weiter
Es akzeptiert die folgenden optionalen Parameter:
Scan
Dies bestimmt, ob das Zeilensprungbild aus dem geraden (tff - Standard) oder
ungerade (bff) Zeilen des progressiven Frames.
Tiefpass
Aktivieren (Standard) oder deaktivieren Sie den vertikalen Tiefpassfilter, um Twitter-Interlacing zu vermeiden
und Moiré-Muster reduzieren.
kerndeint
Deinterlacen Sie das Eingangsvideo, indem Sie das adaptive Kernel-Deinterling von Donald Graft anwenden. Arbeite an
Interlaced-Teile eines Videos, um progressive Frames zu erzeugen.
Die Beschreibung der akzeptierten Parameter folgt.
dreschen
Legen Sie den Schwellenwert fest, der die Toleranz des Filters beeinflusst, wenn Sie bestimmen, ob ein Pixel
Zeile verarbeitet werden muss. Es muss eine ganze Zahl im Bereich [0,255] sein und ist standardmäßig 10.
Ein Wert von 0 führt dazu, dass der Prozess auf alle Pixel angewendet wird.
Karte Malen Sie Pixel, die den Schwellenwert überschreiten, in Weiß, wenn der Wert auf 1 eingestellt ist. Der Standardwert ist 0.
Auftrag
Legen Sie die Reihenfolge der Felder fest. Felder tauschen, wenn auf 1 gesetzt, Felder in Ruhe lassen, wenn 0. Der Standardwert ist 0.
scharf
Aktivieren Sie zusätzliches Schärfen, wenn es auf 1 gesetzt ist. Der Standardwert ist 0.
zwei
Aktivieren Sie das Zweiwege-Schärfen, wenn es auf 1 eingestellt ist. Der Standardwert ist 0.
Beispiele
· Standardwerte anwenden:
kerndeint=thresh=10:map=0:order=0:sharp=0:twoway=0
· Zusätzliches Schärfen aktivieren:
kerndeint=scharf=1
· Verarbeitete Pixel in Weiß malen:
kerndeint=map=1
Linsenkorrektur
Korrigieren Sie die radiale Linsenverzerrung
Dieser Filter kann verwendet werden, um radiale Verzerrungen zu korrigieren, die sich aus der Verwendung von ergeben können
Weitwinkelobjektive und korrigieren dadurch das Bild neu. Um die richtigen Parameter zu finden, kann man
Verwenden Sie Tools, die zum Beispiel als Teil von Opencv verfügbar sind, oder einfach Trial-and-Error. Benutzen
opencv verwendet die Kalibrierungsprobe (unter Samples/cpp) aus den opencv-Quellen und extrahiert
die Koeffizienten k1 und k2 aus der resultierenden Matrix.
Beachten Sie, dass praktisch der gleiche Filter in den Open-Source-Tools Krita und . verfügbar ist
Digikam aus dem KDE-Projekt.
Im Gegensatz zu Vignette Filter, der auch zur Kompensation von Objektivfehlern verwendet werden kann, dies
Filter korrigiert die Verzerrung des Bildes, während Vignette korrigiert die Helligkeit
Verteilung, daher können Sie in bestimmten Fällen beide Filter zusammen verwenden, obwohl Sie
muss sich um die Bestellung kümmern, dh ob vorher eine Vignettierung angebracht werden soll oder
nach der Linsenkorrektur.
Optionen
Der Filter akzeptiert die folgenden Optionen:
cx Relative x-Koordinate des Brennpunktes des Bildes und damit der Mitte des
Verzerrung. Dieser Wert hat einen Bereich von [0,1] und wird als Bruchteile des Bildes ausgedrückt
Breite.
cy Relative y-Koordinate des Brennpunktes des Bildes und damit der Mitte des
Verzerrung. Dieser Wert hat einen Bereich von [0,1] und wird als Bruchteile des Bildes ausgedrückt
Höhe.
k1 Koeffizient des quadratischen Korrekturterms. 0.5 bedeutet keine Korrektur.
k2 Koeffizient des doppelt-quadratischen Korrekturterms. 0.5 bedeutet keine Korrektur.
Die Formel, die die Korrektur erzeugt, lautet:
r_src = r_tgt * (1 + k1 * (r_tgt / r_0)^2 + k2 * (r_tgt / r_0)^4)
woher r_0 ist die Hälfte der Bilddiagonale und r_src und r_tgt sind die Entfernungen von der
Brennpunkt im Quell- bzw. Zielbild.
lut3d
Wenden Sie eine 3D-LUT auf ein Eingangsvideo an.
Der Filter akzeptiert die folgenden Optionen:
Datei
Legen Sie den Namen der 3D-LUT-Datei fest.
Derzeit unterstützte Formate:
3dl Nachwirkungen
Würfel
Iridas
dat DaVinci
m3d Pandora
interp
Wählen Sie den Interpolationsmodus.
Verfügbare Werte sind:
nächste
Verwenden Sie Werte vom nächsten definierten Punkt.
trilinear
Interpolieren Sie die Werte mit den 8 Punkten, die einen Würfel definieren.
tetraedrisch
Werte mit einem Tetraeder interpolieren.
Schlampe, lutrgb, Lutjuw
Berechnen einer Nachschlagetabelle zum Binden jedes Pixelkomponenten-Eingabewerts an einen Ausgabewert,
und wenden Sie es auf das Eingangsvideo an.
Lutjuw wendet eine Lookup-Tabelle auf ein YUV-Eingangsvideo an, lutrgb zu einem RGB-Eingangsvideo.
Diese Filter akzeptieren die folgenden Parameter:
c0 Setze den ersten Pixelkomponentenausdruck
c1 zweiten Pixelkomponentenausdruck setzen
c2 dritten Pixelkomponentenausdruck setzen
c3 vierten Pixelkomponentenausdruck setzen, entspricht der Alphakomponente
r roten Komponentenausdruck setzen
g setze den grünen Komponentenausdruck
b Blaukomponentenausdruck einstellen
a Alpha-Komponenten-Ausdruck
y Y-/Luminanzkomponentenausdruck einstellen
u U/Cb-Komponentenausdruck setzen
v V/Cr-Komponentenausdruck einstellen
Jeder von ihnen gibt den Ausdruck an, der zum Berechnen der Nachschlagetabelle für die
entsprechenden Pixelkomponentenwerte.
Die genaue Komponente, die jedem der c* Optionen hängen vom Format in der Eingabe ab.
Die lut Filter erfordert entweder YUV- oder RGB-Pixelformate in der Eingabe, lutrgb erfordert RGB
Pixelformate in der Eingabe und Lutjuw erfordert YUV.
Die Ausdrücke können die folgenden Konstanten und Funktionen enthalten:
w
h Die Eingabebreite und -höhe.
Welle Der Eingabewert für die Pixelkomponente.
Clipval
Der Eingabewert, beschnitten auf den Minval-maxval range.
maxval
Der maximale Wert für die Pixelkomponente.
Minval
Der Mindestwert für die Pixelkomponente.
Negativ
Der negierte Wert für den Pixelkomponentenwert, beschnitten auf Minval-maxval Angebot;
es entspricht dem Ausdruck "maxval-clipval+minval".
Clip(val)
Der berechnete Wert in Welle, angeschnitten Minval-maxval range.
Gammaval (Gamma)
Der berechnete Gammakorrekturwert des Pixelkomponentenwerts, beschnitten auf
Minval-maxval Palette. Es entspricht dem Ausdruck
"pow((clipval-minval)/(maxval-minval)\,Gamma)*(maxval-minval)+minval"
Alle Ausdrücke sind standardmäßig auf "val" eingestellt.
Beispiele
· Eingabevideo negieren:
lutrgb="r=maxval+minval-val:g=maxval+minval-val:b=maxval+minval-val"
lutyuv="y=maxval+minval-val:u=maxval+minval-val:v=maxval+minval-val"
Das obige ist dasselbe wie:
lutrgb="r=negval:g=negval:b=negval"
lutyuv="y=negval:u=negval:v=negval"
· Luminanz negieren:
lutyuv=y=negval
· Entfernen Sie Chroma-Komponenten und verwandeln Sie das Video in ein Grautonbild:
lutyuv="u=128:v=128"
· Wenden Sie einen Luma-Burning-Effekt an:
lutyuv="y=2*val"
· Grüne und blaue Komponenten entfernen:
lutrgb="g=0:b=0"
· Stellen Sie einen konstanten Alphakanalwert für die Eingabe ein:
format=rgba,lutrgb=a="maxval-minval/2"
· Korrigieren Sie das Luminanz-Gamma um den Faktor 0.5:
lutyuv=y=gammaval(0.5)
· Niedrigstwertige Bits von Luma verwerfen:
lutyuv=y='bitand(val, 128+64+32)'
Zusammenführungsebenen
Farbkanalkomponenten aus mehreren Videostreams zusammenführen.
Der Filter akzeptiert bis zu 4 Eingabestreams und führt ausgewählte Eingabeebenen mit der Ausgabe zusammen
Video.
Dieser Filter akzeptiert die folgenden Optionen:
Mapping
Legen Sie die Zuordnung der Eingabe- zur Ausgabeebene fest. Standard ist 0.
Die Zuordnungen werden als Bitmap angegeben. Sie sollte als Hexadezimalzahl angegeben werden
in der Form 0xAa[Bb[Cc[Dd]]]. 'Aa' beschreibt die Abbildung für die erste Ebene des
Ausgabestrom. 'A' legt die Nummer des zu verwendenden Eingabestreams fest (von 0 bis 3), und 'a'
die Ebenennummer des entsprechenden zu verwendenden Eingangs (von 0 bis 3). Der Rest des
Mappings ist ähnlich, 'Bb' beschreibt das Mapping für die zweite Ebene des Ausgabestroms,
'Cc' beschreibt das Mapping für die dritte Ebene des Ausgabestroms und 'Dd' beschreibt die
Mapping für die vierte Ebene des Ausgabestroms.
Format
Legen Sie das Ausgabepixelformat fest. Standard ist "yuva444p".
Beispiele
· Drei graue Videostreams gleicher Breite und Höhe zu einem einzigen Videostream zusammenführen:
[a0][a1][a2]mergeplanes=0x001020:yuv444p
· 1. yuv444p-Stream und 2. grauer Videostream in den yuva444p-Videostream zusammenführen:
[a0][a1]mergeplanes=0x00010210:yuva444p
· Tauschen Sie die Y- und A-Ebene im yuva444p-Stream aus:
format=yuva444p,mergeplanes=0x03010200:yuva444p
· U- und V-Ebene im yuv420p-Stream tauschen:
format=yuv420p,mergeplanes=0x000201:yuv420p
· Cast einen rgb24-Clip in yuv444p:
format=rgb24,mergeplanes=0x000102:yuv444p
mcdeint
Wenden Sie Deinterlacing mit Bewegungskompensation an.
Es benötigt ein Halbbild pro Frame als Eingabe und muss daher zusammen mit yadif=1/3 oder . verwendet werden
gleichwertig.
Dieser Filter akzeptiert die folgenden Optionen:
Modus
Stellen Sie den Deinterlacing-Modus ein.
Es akzeptiert einen der folgenden Werte:
schnell
mittlere
langsam
iterative Bewegungsschätzung verwenden
extra_langsam
Gefällt mir langsam, aber verwenden Sie mehrere Referenzrahmen.
Standardwert ist schnell.
Parität
Stellen Sie die für das Eingangsvideo angenommene Bildfeldparität ein. Es muss einer von denen sein
folgende Werte:
0, tff
Nehmen Sie zuerst das obere Feld an
1, bff
unterstes Feld zuerst annehmen
Standardwert ist bff.
qp Stellen Sie den Block-Quantisierungsparameter (QP) ein, der vom internen Encoder verwendet wird.
Höhere Werte sollten zu einem glatteren Bewegungsvektorfeld führen, aber weniger optimal
einzelne Vektoren. Der Standardwert ist 1.
mpdezimieren
Drop-Frames, die sich nicht wesentlich vom vorherigen Frame unterscheiden, um Frames zu reduzieren
Preis.
Die Hauptanwendung dieses Filters ist die Codierung mit sehr niedriger Bitrate (z. B. Streaming über Einwahl
Modem), aber es könnte theoretisch zum Reparieren von Filmen verwendet werden, die inverse-telecined waren
falsch.
Eine Beschreibung der akzeptierten Optionen folgt.
max Legen Sie die maximale Anzahl aufeinanderfolgender Frames fest, die gelöscht werden können (falls positiv), oder
das minimale Intervall zwischen ausgelassenen Frames (falls negativ). Wenn der Wert 0 ist, wird der
Frame wird verworfen, ungeachtet der Anzahl der vorherigen sequentiell verworfenen Frames.
Der Standardwert ist 0.
hi
lo
Frack
Legen Sie die Abfallschwellenwerte fest.
Werte für hi und lo sind für 8x8 Pixelblöcke und repräsentieren den tatsächlichen Pixelwert
Unterschiede, so dass ein Schwellenwert von 64 einer Differenzeinheit für jedes Pixel entspricht,
oder dasselbe anders über den Block verteilt.
Ein Frame ist ein Kandidat für das Verwerfen, wenn sich keine 8x8-Blöcke um mehr als einen Schwellenwert unterscheiden
of hi, und wenn nicht mehr als Frack Blöcke (1 bedeutet das ganze Bild) unterscheiden sich um mehr als
eine Schwelle von lo.
Standardwert für hi ist 64*12, Standardwert für lo ist 64*5 und der Standardwert für
Frack ist 0.33.
negiere
Eingangsvideo negieren.
Es akzeptiert eine ganze Zahl als Eingabe; wenn nicht Null, wird die Alpha-Komponente (sofern verfügbar) negiert.
Der Standardwert in der Eingabe ist 0.
kein Format
Zwingen Sie libavfilter, keines der angegebenen Pixelformate für die Eingabe zum nächsten zu verwenden
Filter.
Es akzeptiert die folgenden Parameter:
pix_fmts
Eine durch '|' getrennte Liste von Pixelformatnamen, z. B. apix_fmts=yuv420p|monow|rgb24".
Beispiele
· Erzwinge, dass libavfilter ein anderes Format verwendet als yuv420p für die Eingabe in den vflip
Filter:
noformat=pix_fmts=yuv420p,vflip
· Konvertieren Sie das Eingabevideo in eines der Formate, die nicht in der Liste enthalten sind:
noformat=yuv420p|yuv444p|yuv410p
Lärm
Rauschen im Videoeingangsbild hinzufügen.
Der Filter akzeptiert die folgenden Optionen:
all_seed
c0_seed
c1_seed
c2_seed
c3_seed
Legen Sie den Rausch-Seed für eine bestimmte Pixelkomponente oder alle Pixelkomponenten fest, falls
all_seed. Der Standardwert ist 123457.
alle_stärke, alles
c0_Stärke, c0s
c1_Stärke, c1s
c2_Stärke, c2s
c3_Stärke, c3s
Legen Sie die Rauschstärke für eine bestimmte Pixelkomponente oder alle Pixelkomponenten fest, falls
all_strength. Der Standardwert ist 0. Der zulässige Bereich ist [0, 100].
alle_flaggen, allf
c0_flags, C0f
c1_flags, C1f
c2_flags, C2f
c3_flags, C3f
Setzen Sie Pixelkomponenten-Flags oder setzen Sie Flags für alle Komponenten, wenn alle_flaggen. Verfügbar
Werte für Komponenten-Flags sind:
a gemitteltes zeitliches Rauschen (weicher)
p zufälliges Rauschen mit einem (halb)regelmäßigen Muster mischen
t zeitliches Rauschen (das Rauschmuster ändert sich zwischen den Bildern)
u gleichmäßiges Rauschen (sonst Gauss)
Beispiele
Fügen Sie dem Eingangsvideo zeitliches und gleichmäßiges Rauschen hinzu:
Rauschen=alles=20:allf=t+u
null
Übergeben Sie die Videoquelle unverändert an den Ausgang.
OCV
Wenden Sie eine Videotransformation mit libopencv an.
Um diesen Filter zu aktivieren, installieren Sie die libopencv-Bibliothek und -Header und konfigurieren Sie FFmpeg mit
"--enable-libopencv".
Es akzeptiert die folgenden Parameter:
Filtername
Der Name des anzuwendenden libopencv-Filters.
filter_params
Die an den libopencv-Filter zu übergebenden Parameter. Wenn nicht angegeben, die Standardwerte
sind angenommen.
Genauere Informationen finden Sie in der offiziellen libopencv-Dokumentation:
<http://docs.opencv.org/master/modules/imgproc/doc/filtering.html>
Mehrere libopencv-Filter werden unterstützt; siehe die folgenden Unterabschnitte.
erweitern
Erweitern Sie ein Bild, indem Sie ein bestimmtes strukturierendes Element verwenden. Es entspricht der libopencv
Funktion "cvDilate".
Es akzeptiert die Parameter: struct_el|nb_iterationen.
struct_el stellt ein strukturierendes Element dar und hat die Syntax:
SpaltenxReihen+Anker_xxAnker_y/gestalten
Spalten und Reihen die Anzahl der Spalten und Zeilen des strukturierenden Elements darstellen,
Anker_x und Anker_y der Ankerpunkt und gestalten die Form für das strukturierende Element.
gestalten muss "rect", "cross", "ellipse" oder "custom" sein.
Wenn der Wert für gestalten ist "benutzerdefiniert", gefolgt von einer Zeichenfolge der Form
"=Dateinamen". Die Datei mit dem Namen Dateinamen wird angenommen, dass es ein binäres Bild darstellt, wobei jedes
druckbares Zeichen, das einem hellen Pixel entspricht. Wenn ein Brauch gestalten wird genutzt, Spalten und
Reihen ignoriert, sondern die Anzahl bzw. Spalten und Zeilen der gelesenen Datei übernommen.
Der Standardwert für struct_el ist "3x3+0x0/Rechteck".
nb_iterationen gibt an, wie oft die Transformation auf das Bild angewendet wird, und
standardmäßig auf 1.
Einige Beispiele:
# Verwenden Sie die Standardwerte
ocv=dilatieren
# Dilatieren Sie mit einem strukturierenden Element mit einem 5x5-Kreuz, das zweimal iteriert
ocv=filter_name=dilate:filter_params=5x5+2x2/cross|2
# Lesen Sie die Form aus der Datei diamond.shape, und wiederholen Sie sie zweimal.
# Die Datei diamant.shape kann ein solches Zeichenmuster enthalten
# *
#***
#*****
#***
# *
# Die angegebenen Spalten und Zeilen werden ignoriert
# aber die Ankerpunktkoordinaten sind nicht
ocv=dilate:0x0+2x2/custom=diamond.shape|2
erodieren
Erodieren Sie ein Bild, indem Sie ein bestimmtes Strukturierungselement verwenden. Es entspricht der libopencv
Funktion "cvErode".
Es akzeptiert die Parameter: struct_el:nb_iterationen, mit der gleichen Syntax und Semantik wie
erweitern Filter.
glätten
Glätten Sie das Eingangsvideo.
Der Filter nimmt die folgenden Parameter an: tippe|param1|param2|param3|param4.
tippe ist der anzuwendende Glättungsfiltertyp und muss einer der folgenden Werte sein:
"blur", "blur_no_scale", "median", "gaußian" oder "bilateral". Der Standardwert ist
"Gaußisch".
Die Bedeutung von param1, param2, param3 und param4 hängen vom glatten Typ ab. param1 und
param2 akzeptieren ganzzahlige positive Werte oder 0. param3 und param4 Gleitkomma akzeptieren
Werte.
Der Standardwert für param1 ist 3. Der Standardwert für die anderen Parameter ist 0.
Diese Parameter entsprechen den Parametern, die der libopencv-Funktion zugewiesen sind
"cvSmooth".
Auflage
Überlagern Sie ein Video über ein anderes.
Es braucht zwei Eingänge und hat einen Ausgang. Der erste Eingang ist das "Haupt"-Video, auf dem die
zweiter Eingang wird überlagert.
Es akzeptiert die folgenden Parameter:
Eine Beschreibung der akzeptierten Optionen folgt.
x
y Legen Sie den Ausdruck für die x- und y-Koordinaten des überlagerten Videos auf dem Hauptbildschirm fest
Video. Der Standardwert ist für beide Ausdrücke "0". Falls der Ausdruck ungültig ist,
es ist auf einen großen Wert eingestellt (was bedeutet, dass das Overlay nicht innerhalb des
Ausgabe sichtbarer Bereich).
eof_action
Die Aktion, die ausgeführt werden soll, wenn EOF an der sekundären Eingabe auftritt; es akzeptiert einen von
folgende Werte:
wiederholen
Wiederholen Sie den letzten Frame (Standardeinstellung).
Beende alles
Beende beide Streams.
passieren
Leiten Sie den Haupteingang durch.
eval
Legen Sie fest, wann die Ausdrücke für x und y bewertet werden.
Es akzeptiert die folgenden Werte:
init
werte Ausdrücke nur einmal während der Filterinitialisierung aus oder wenn ein Befehl
wird verarbeitet
Rahmen
werte Ausdrücke für jeden eingehenden Frame aus
Standardwert ist Rahmen.
kürzeste
Wenn auf 1 gesetzt, erzwingen Sie, dass die Ausgabe beendet wird, wenn die kürzeste Eingabe endet. Standard
Wert ist 0.
Format
Legen Sie das Format für das Ausgabevideo fest.
Es akzeptiert die folgenden Werte:
yuv420
YUV420-Ausgang erzwingen
yuv422
YUV422-Ausgang erzwingen
yuv444
YUV444-Ausgang erzwingen
RGB RGB-Ausgabe erzwingen
Standardwert ist yuv420.
RGB (veraltet)
Wenn auf 1 gesetzt, wird der Filter gezwungen, Eingaben im RGB-Farbraum zu akzeptieren. Standardwert
ist 0. Diese Option ist veraltet, verwenden Sie Format stattdessen.
wiederholen
Wenn der Wert auf 1 gesetzt ist, zwingt Sie den Filter, den letzten Overlay-Frame über den Haupteingang zu zeichnen, bis
das Ende des Streams. Ein Wert von 0 deaktiviert dieses Verhalten. Der Standardwert ist 1.
Die x und y Ausdrücke können die folgenden Parameter enthalten.
main_w, W
main_h, H
Breite und Höhe der Haupteingabe.
overlay_w, w
overlay_h, h
Die Overlay-Eingabebreite und -höhe.
x
y Die berechneten Werte für x und y. Sie werden für jeden neuen Frame ausgewertet.
hsub
vssub
horizontale und vertikale Chroma-Subsample-Werte des Ausgabeformats. Zum Beispiel für
das Pixelformat "yuv422p" hsub ist 2 und vssub ist 1.
n die Anzahl der Eingaberahmen, beginnend bei 0
Post die Position in der Datei des Eingabeframes, NAN falls unbekannt
t Der Zeitstempel, ausgedrückt in Sekunden. Es ist NAN, wenn der Eingabezeitstempel unbekannt ist.
Beachten Sie, dass die n, Post, t Variablen sind nur verfügbar, wenn die Auswertung abgeschlossen ist für Rahmen,
und wird zu NAN ausgewertet, wenn eval eingestellt ist init.
Beachten Sie, dass die Frames von jedem Eingangsvideo in der Zeitstempelreihenfolge genommen werden, daher, wenn ihre
Anfangszeitstempel unterschiedlich sind, ist es eine gute Idee, die beiden Eingaben über a . zu übergeben
setpts=PTS-STARTPTS filtern, damit sie mit demselben Nullzeitstempel beginnen, wie im Beispiel
für die Film Filter tut.
Sie können mehrere Overlays verketten, sollten jedoch die Effizienz eines solchen Ansatzes testen.
Befehle
Dieser Filter unterstützt die folgenden Befehle:
x
y Ändern Sie x und y der Overlay-Eingabe. Der Befehl akzeptiert die gleiche Syntax wie der
entsprechende Option.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
Beispiele
· Zeichnen Sie das Overlay 10 Pixel von der unteren rechten Ecke des Hauptvideos:
overlay=main_w-overlay_w-10:main_h-overlay_h-10
Mit benannten Optionen wird das obige Beispiel zu:
overlay=x=main_w-overlay_w-10:y=main_h-overlay_h-10
· Fügen Sie ein transparentes PNG-Logo in der unteren linken Ecke der Eingabe ein, indem Sie die ffmpeg
Tool mit der Option "-filter_complex":
ffmpeg -i Eingabe -i Logo -filter_complex 'overlay=10:main_h-overlay_h-10' Ausgabe
· Fügen Sie 2 verschiedene transparente PNG-Logos ein (zweites Logo in der unteren rechten Ecke) mit
ffmpeg Tool:
ffmpeg -i Eingabe -i Logo1 -i Logo2 -filter_complex 'overlay=x=10:y=Hh-10,overlay=x=Ww-10:y=Hh-10' Ausgabe
· Fügen Sie eine transparente Farbebene über dem Hauptvideo hinzu; "BxH" muss die Größe von . angeben
der Haupteingang zum Overlay-Filter:
[E-Mail geschützt] :size=BxH [über]; [in][over] Overlay [out]
· Spielen Sie ein Originalvideo und eine gefilterte Version (hier mit dem Deshake-Filter) nebeneinander ab
Seite mit der ffplay Tool:
ffplay input.avi -vf 'split[a][b]; [a]pad=iw*2:ih[src]; [b]entrütteln[filtrieren]; [src][filt]overlay=w'
Der obige Befehl ist der gleiche wie:
ffplay input.avi -vf 'split[b], pad=iw*2[src], [b]deshake, [src]overlay=w'
· Lassen Sie eine gleitende Überlagerung vom linken zum rechten oberen Teil des Bildschirms erscheinen
ab Zeitpunkt 2:
overlay=x='if(gte(t,2), -w+(t-2)*20, NAN)':y=0
· Verfassen Sie die Ausgabe, indem Sie zwei Eingabevideos nebeneinander platzieren:
ffmpeg -i left.avi -i right.avi -filter_complex "
nullsrc=size=200x100 [Hintergrund];
[0:v] setpts=PTS-STARTPTS, scale=100x100 [links];
[1:v] setpts=PTS-STARTPTS, scale=100x100 [rechts];
[Hintergrund][Links] Overlay=kürzeste=1 [Hintergrund+Links];
[Hintergrund+links][rechts] Overlay=kürzeste=1:x=100 [links+rechts]
"
· Maskieren Sie 10-20 Sekunden eines Videos, indem Sie den Delogo-Filter auf einen Abschnitt anwenden
ffmpeg -i test.avi -codec:v:0 wmv2 -ar 11025 -b:v 9000k
-vf '[in]split[split_main][split_delogo];[split_delogo]trim=start=360:end=371,delogo=0:0:640:480[delogoed];[split_main][delogoed]overlay=eof_action=pass[out]'
maskiert.avi
· Mehrere Overlays in Kaskade verketten:
nullsrc=s=200x200 [bg];
testsrc=s=100x100, split=4 [in0][in1][in2][in3];
[in0] lutrgb=r=0, [bg] Überlagerung=0:0 [mid0];
[in1] lutrgb=g=0, [mid0] Overlay=100:0 [mid1];
[in2] lutrgb=b=0, [mid1] Overlay=0:100 [mid2];
[in3] null, [mid2] Overlay=100:100 [out0]
Owdenoise
Wenden Sie den Overcomplete Wavelet-Denoiser an.
Der Filter akzeptiert die folgenden Optionen:
Tiefe
Tiefe einstellen.
Größere Tiefenwerte entrauschen niedrigere Frequenzkomponenten stärker, verlangsamen jedoch
Filterung.
Muss ein int im Bereich von 8-16 sein, der Standardwert ist 8.
luma_stärke, ls
Stellen Sie die Luma-Stärke ein.
Muss ein Double-Wert im Bereich von 0-1000 sein, der Standardwert ist 1.0.
Chroma_Stärke, cs
Stellen Sie die Chroma-Stärke ein.
Muss ein Double-Wert im Bereich von 0-1000 sein, der Standardwert ist 1.0.
Unterlage
Fügen Sie dem Eingabebild Abstände hinzu und platzieren Sie die ursprüngliche Eingabe an der bereitgestellten x, y
Koordinaten.
Es akzeptiert die folgenden Parameter:
Breite, w
Höhe, h
Geben Sie einen Ausdruck für die Größe des Ausgabebilds mit den hinzugefügten Auffüllungen an. Wenn die
Wert für Breite or Höhe 0 ist, wird die entsprechende Eingabegröße für die Ausgabe verwendet.
Die Breite Ausdruck kann auf den Wert verweisen, der durch die Höhe Ausdruck und Laster
versa.
Der Standardwert von Breite und Höhe ist 0.
x
y Geben Sie die Versätze an, an denen das Eingabebild innerhalb des aufgefüllten Bereichs platziert werden soll
zum oberen/linken Rand des Ausgabebilds.
Die x Ausdruck kann auf den Wert verweisen, der durch die y Ausdruck und umgekehrt.
Der Standardwert von x und y ist 0.
Farbe
Geben Sie die Farbe des aufgefüllten Bereichs an. Die Syntax dieser Option finden Sie unter "Farbe".
Abschnitt im ffmpeg-utils-Handbuch.
Der Standardwert von Farbe ist schwarz".
Der Wert für die Breite, Höhe, x und y Optionen sind Ausdrücke, die Folgendes enthalten
Konstanten:
in_w
in_h
Die Breite und Höhe des Eingangsvideos.
iw
ih Das sind die gleichen wie in_w und in_h.
aus_w
aus_h
Die Ausgabebreite und -höhe (die Größe des aufgefüllten Bereichs), wie durch die Breite
und Höhe Ausdrücke.
ow
oh Das sind die gleichen wie aus_w und aus_h.
x
y Die x- und y-Offsets, wie durch die x und y Ausdrücke, oder NAN, wenn noch nicht
spezifiziert.
a wie iw / ih
sar Seitenverhältnis des Eingabebeispiels
geben das Seitenverhältnis der Eingabeanzeige ist dasselbe wie (iw / ih) * sar
hsub
vssub
Die horizontalen und vertikalen Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
Beispiele
· Füllen Sie das Eingabevideo mit der Farbe "Violett" auf. Die Ausgabevideogröße ist
640x480, und die obere linke Ecke des Eingabevideos wird in Spalte 0, Zeile 40 . platziert
pad=640:480:0:40:violett
Das obige Beispiel entspricht dem folgenden Befehl:
pad=width=640:height=480:x=0:y=40:color=violett
· Füllen Sie die Eingabe auf, um eine Ausgabe mit um 3/2 vergrößerten Dimensionen zu erhalten, und setzen Sie die Eingabe
Video in der Mitte des gepolsterten Bereichs:
pad="3/2*iw:3/2*ih:(ow-iw)/2:(oh-ih)/2"
· Füllen Sie die Eingabe auf, um eine quadrierte Ausgabe zu erhalten, deren Größe dem Maximalwert zwischen den entspricht
Geben Sie Breite und Höhe ein und platzieren Sie das Eingabevideo in der Mitte des aufgefüllten Bereichs:
pad="max(iw\,ih):ow:(ow-iw)/2:(oh-ih)/2"
· Füllen Sie die Eingabe auf, um ein endgültiges W/H-Verhältnis von 16:9 zu erhalten:
pad="ih*16/9:ih:(ow-iw)/2:(oh-ih)/2"
· Im Falle von anamorphotischem Video, um das Ausgabeanzeige-Seitenverhältnis richtig einzustellen,
ist notwendig zu verwenden sar im Ausdruck nach der Beziehung:
(ih * X / ih) * sar = ausgabe_dar
X = Ausgabe_dar / sar
Daher muss das vorherige Beispiel geändert werden, um:
pad="ih*16/9/sar:ih:(ow-iw)/2:(oh-ih)/2"
· Verdoppeln Sie die Ausgabegröße und platzieren Sie das Eingabevideo in der unteren rechten Ecke des
Ausgabe gepolsterter Bereich:
pad="2*iw:2*ih:ow-iw:oh-ih"
paletten
Generieren Sie eine Palette für einen ganzen Videostream.
Es akzeptiert die folgenden Optionen:
max_farben
Legen Sie die maximale Anzahl von Farben für die Quantisierung in der Palette fest. Hinweis: Die Palette wird
enthalten noch 256 Farben; die unbenutzten Paletteneinträge sind schwarz.
Reserve_transparent
Erstellen Sie eine Palette von maximal 255 Farben und reservieren Sie die letzte für Transparenz.
Das Reservieren der Transparenzfarbe ist für die GIF-Optimierung nützlich. Wenn nicht eingestellt, wird die
Die maximale Anzahl von Farben in der Palette beträgt 256. Sie möchten diese Option wahrscheinlich deaktivieren
für ein eigenständiges Bild. Standardmäßig eingestellt.
stats_mode
Statistikmodus einstellen.
Es akzeptiert die folgenden Werte:
voller
Berechnen Sie Vollbild-Histogramme.
diff
Berechnen Sie Histogramme nur für den Teil, der sich vom vorherigen Frame unterscheidet. Das könnte
relevant sein, um dem beweglichen Teil Ihrer Eingabe mehr Bedeutung zu verleihen, wenn die
Hintergrund ist statisch.
Standardwert ist voller.
Der Filter exportiert auch die Frame-Metadaten "lavfi.color_quant_ratio" ("nb_color_in /
nb_color_out"), mit dem Sie den Grad der Farbquantisierung der
Palette. Diese Informationen sind auch sichtbar unter Info Protokollierungsebene.
Beispiele
· Erstellen Sie eine repräsentative Palette eines bestimmten Videos mit ffmpeg:
ffmpeg -i input.mkv -vf palettegen palette.png
Palettennutzung
Verwenden Sie eine Palette, um einen Eingangsvideostream herunterzurechnen.
Der Filter benötigt zwei Eingaben: einen Videostream und eine Palette. Die Palette muss ein 256 . sein
Pixel Bild.
Es akzeptiert die folgenden Optionen:
Dithering
Wählen Sie den Dithering-Modus. Verfügbare Algorithmen sind:
bayer
Bestelltes 8x8 Bayer Dithering (deterministisch)
Heckbert
Dithering nach Paul Heckbert 1982 (einfache Fehlerdiffusion). Notiz:
dieses Dithering wird manchmal als "falsch" angesehen und als Referenz angegeben.
floyd_steinberg
Floyd- und Steingberg-Dithering (Fehlerdiffusion)
sierra2
Frankie Sierra Dithering v2 (Fehlerdiffusion)
sierra2_4a
Frankie Sierra Dithering v2 "Lite" (Fehlerdiffusion)
Standardeinstellung ist sierra2_4a.
bayer_waage
Wann bayer Dithering ausgewählt ist, definiert diese Option die Skalierung des Musters (wie
viel das Schraffurmuster ist sichtbar). Ein niedriger Wert bedeutet sichtbareres Muster für
weniger Streifenbildung, und ein höherer Wert bedeutet weniger sichtbares Muster auf Kosten von mehr Streifenbildung.
Die Option muss ein ganzzahliger Wert im Bereich [0,5] sein. Standard ist 2.
diff_mode
Falls eingestellt, definieren Sie die zu verarbeitende Zone
Rechteck
Nur das sich ändernde Rechteck wird erneut verarbeitet. Dies ist ähnlich wie bei GIF
Beschneidungs-/Offset-Kompressionsmechanismus. Diese Option kann für die Geschwindigkeit nützlich sein, wenn
nur ein Teil des Bildes ändert sich und hat Anwendungsfälle wie die Begrenzung des Umfangs
der Fehlerdiffusion Dithering auf das Rechteck, das die bewegte Szene begrenzt (es
führt zu einer deterministischen Ausgabe, wenn sich die Szene nicht viel ändert, und wie
Ergebnis weniger Bewegungsrauschen und bessere GIF-Komprimierung).
Standardeinstellung ist keine.
Beispiele
· Verwenden Sie eine Palette (erzeugt zum Beispiel mit paletten) um ein GIF mit zu codieren ffmpeg:
ffmpeg -i input.mkv -i palette.png -lavfi paletteuse output.gif
Perspektive
Korrekte Perspektive des Videos, das nicht senkrecht zum Bildschirm aufgenommen wurde.
Eine Beschreibung der akzeptierten Parameter folgt.
x0
y0
x1
y1
x2
y2
x3
y3 Koordinatenausdruck für oben links, oben rechts, unten links und unten rechts festlegen
Ecken. Standardwerte sind "0:0:W:0:0:H:W:H", mit der Perspektive bleibt
unverändert. Wenn die Option "sense" auf "source" gesetzt ist, werden die angegebenen Punkte
in die Ecken des Ziels geschickt werden. Wenn die Option "Sinn" auf eingestellt ist
"Ziel", dann werden die Ecken der Quelle an das angegebene gesendet
Koordinaten.
Die Ausdrücke können die folgenden Variablen verwenden:
W
H die Breite und Höhe des Videorahmens.
Interpolation
Stellen Sie die Interpolation für die Perspektivenkorrektur ein.
Es akzeptiert die folgenden Werte:
linear
kubisch
Standardwert ist linear.
Sinn
Legen Sie die Interpretation der Koordinatenoptionen fest.
Es akzeptiert die folgenden Werte:
0, Quelle
Punkt in der durch die angegebenen Koordinaten angegebenen Quelle an die Ecken des senden
Ziel.
1, Reiseziel
Senden Sie die Ecken der Quelle an den Punkt im Ziel, der durch die
Koordinaten gegeben.
Standardwert ist Quelle.
Phase
Interlaced-Video um eine Halbbildzeit verzögern, damit sich die Halbbildreihenfolge ändert.
Der Verwendungszweck besteht darin, PAL-Filme zu reparieren, die mit dem entgegengesetzten Halbbild aufgenommen wurden
Auftrag zur Film-zu-Video-Übertragung.
Eine Beschreibung der akzeptierten Parameter folgt.
Modus
Phasenmodus einstellen.
Es akzeptiert die folgenden Werte:
t Feldreihenfolge oben-zuerst erfassen, unten-zuerst übertragen. Filter verzögert die
unteres Feld.
b Feldreihenfolge unten-zuerst erfassen, oben-zuerst übertragen. Filter verzögert die Spitze
Feld.
p Erfassen und übertragen Sie mit derselben Feldreihenfolge. Dieser Modus existiert nur für die
Dokumentation der anderen Optionen, auf die Sie verweisen können, aber wenn Sie sie tatsächlich auswählen, wird die
Filter wird treu nichts tun.
a Feldreihenfolge erfassen automatisch durch Feldflags bestimmt, Übergabe gegenüber.
Filter wählt zwischen t und b Modi auf einer Frame-für-Frame-Basis unter Verwendung von Feld-Flags. Wenn
keine Feldinformationen vorhanden sind, dann funktioniert das genauso wie u.
u Unbekannt oder variierend erfassen, gegenüber übertragen. Filter wählt zwischen t und b auf einem
Frame für Frame Basis, indem Sie die Bilder analysieren und die Alternative auswählen, die
ergibt die beste Übereinstimmung zwischen den Feldern.
T Erfassen Sie oben zuerst, übertragen Sie unbekannte oder variierende. Filter wählt zwischen t und p
mittels Bildanalyse.
B Unten zuerst erfassen, unbekannt oder variierend übertragen. Filter wählt zwischen b und p
mittels Bildanalyse.
A Erfassung durch Feldflags bestimmt, Übertragung unbekannt oder schwankend. Filterauswahl
unter t, b und p mit Feldflaggen und Bildanalyse. Wenn keine Feldinformationen vorhanden sind
vorhanden, dann funktioniert das genauso U. Dies ist der Standardmodus.
U Beide erfassen und übertragen unbekannt oder variieren. Filter wählt zwischen t, b und p
nur mit Bildanalyse.
Pixeltest
Testfilter für Pixelformatdeskriptoren, hauptsächlich nützlich für interne Tests. Das Ausgabevideo
sollte gleich dem Eingangsvideo sein.
Beispielsweise:
format=monow, pixdesctest
kann verwendet werden, um die Deskriptordefinition des monoweißen Pixelformats zu testen.
pp
Aktivieren Sie die angegebene Kette von Nachverarbeitungs-Subfiltern mit libpostproc. Diese Bibliothek
sollte bei einem GPL-Build automatisch ausgewählt werden ("--enable-gpl"). Unterfilter müssen sein
durch '/' getrennt und kann durch Voranstellen eines '-' deaktiviert werden. Jeder Unterfilter und einige Optionen
haben einen kurzen und einen langen Namen, die austauschbar verwendet werden können, dh dr/dering sind die
Gleiche.
Die Filter akzeptieren die folgenden Optionen:
Unterfilter
Zeichenfolge für Nachbearbeitungs-Subfilter festlegen.
Alle Unterfilter haben gemeinsame Optionen, um ihren Umfang zu bestimmen:
a/autoq
Beachten Sie die Qualitätsbefehle für diesen Unterfilter.
c/chrom
Führen Sie auch eine Chrominanzfilterung durch (Standard).
y/nochrom
Führen Sie nur Luminanzfilterung durch (keine Chrominanz).
n/noluma
Führen Sie nur die Chrominanzfilterung durch (keine Luminanz).
Diese Optionen können nach dem Subfilternamen, getrennt durch ein '|', angehängt werden.
Verfügbare Unterfilter sind:
hb/hdeblock[|Unterschied[|Flachheit]]
Horizontaler Deblocking-Filter
Unterschied
Differenzfaktor, bei dem höhere Werte mehr Deblocking bedeuten (Standard: 32).
Ebenheit
Flatness-Schwellenwert, bei dem niedrigere Werte mehr Deblocking bedeuten (Standard: 39).
vb/vdeblock[|Unterschied[|Flachheit]]
Vertikaler Entblockungsfilter
Unterschied
Differenzfaktor, bei dem höhere Werte mehr Deblocking bedeuten (Standard: 32).
Ebenheit
Flatness-Schwellenwert, bei dem niedrigere Werte mehr Deblocking bedeuten (Standard: 39).
ha/hadeblock[|Unterschied[|Flachheit]]
Genauer horizontaler Deblocking-Filter
Unterschied
Differenzfaktor, bei dem höhere Werte mehr Deblocking bedeuten (Standard: 32).
Ebenheit
Flatness-Schwellenwert, bei dem niedrigere Werte mehr Deblocking bedeuten (Standard: 39).
va/vadeblock[|Unterschied[|Flachheit]]
Genauer vertikaler Deblocking-Filter
Unterschied
Differenzfaktor, bei dem höhere Werte mehr Deblocking bedeuten (Standard: 32).
Ebenheit
Flatness-Schwellenwert, bei dem niedrigere Werte mehr Deblocking bedeuten (Standard: 39).
Die horizontalen und vertikalen Deblocking-Filter teilen sich die Differenz- und Flachheitswerte, so dass
Sie können keine unterschiedlichen horizontalen und vertikalen Schwellenwerte einstellen.
h1/x1hdeblock
Experimenteller horizontaler Deblocking-Filter
v1/x1vdeblock
Experimenteller vertikaler Deblocking-Filter
dr/dering
Deringing-Filter
tn/tmpnoise[|schwelle1[|schwelle2[|schwelle3]]], temporäre Lärm Reduzierstück
Schwelle1
größer -> stärkere Filterung
Schwelle2
größer -> stärkere Filterung
Schwelle3
größer -> stärkere Filterung
al/autolevels[:f/fullrange], maschinell Helligkeit / Kontrast Korrektur
f/Fullrange
Luminanz auf "0-255" dehnen.
lb/linblenddeint
Linear Blend-Deinterlacing-Filter, der den gegebenen Block deinterlaced, indem er alle filtert
Zeilen mit einem "(1 2 1)"-Filter.
li/linipoldeint
Linear interpolierender Deinterlacing-Filter, der den gegebenen Block um deinterlaced
lineare Interpolation jeder zweiten Zeile.
ci/cubicipoldeint
Kubisch interpolierender Deinterlacing-Filter deinterlaced den gegebenen Block um kubisch
jede zweite Zeile interpolieren.
md/mediandeint
Median-Deinterlacing-Filter, der den gegebenen Block durch Anwenden eines Medians deinterlaced
auf jede zweite Zeile filtern.
fd/ffmpegdeint
FFmpeg-Deinterlacing-Filter, der den gegebenen Block deinterlaced, indem er alle filtert
zweite Zeile mit einem "(-1 4 2 4 -1)"-Filter.
l5/Tiefpass5
Vertikal angewendeter FIR-Tiefpass-Deinterlacing-Filter, der den gegebenen Block deinterlaced
indem alle Zeilen mit einem "(-1 2 6 2 -1)"-Filter gefiltert werden.
fq/forceQuant[|Quantisierer]
Überschreibt die Quantisierertabelle aus der Eingabe mit dem von Ihnen angegebenen konstanten Quantisierer.
Quantisierer
Quantisierer zu verwenden
de/Standard
Standard-PP-Filterkombination ("hb|a,vb|a,dr|a")
fa/schnell
Schnelle pp-Filterkombination ("h1|a,v1|a,dr|a")
ac Hochwertige PP-Filterkombination ("ha|a|128|7,va|a,dr|a")
Beispiele
· Wenden Sie horizontales und vertikales Deblocking, Deringing und automatische Helligkeit/Kontrast an:
pp=hb/vb/dr/al
· Standardfilter ohne Helligkeits-/Kontrastkorrektur anwenden:
pp=de/-al
· Standardfilter und Temporal Denoiser anwenden:
pp=default/tmpnoise|1|2|3
· Deblocking nur auf Luminanz anwenden und vertikales Deblocking ein- oder ausschalten
automatisch je nach verfügbarer CPU-Zeit:
pp=hb|y/vb|a
pp7
Nachbearbeitungsfilter anwenden 7. Es ist eine Variante des spp Filter, ähnlich spp = 6 mit 7
Punkt-DCT, wo nur die mittlere Stichprobe nach der IDCT verwendet wird.
Der Filter akzeptiert die folgenden Optionen:
qp Erzwinge einen konstanten Quantisierungsparameter. Es akzeptiert eine ganze Zahl im Bereich von 0 bis 63. Wenn
nicht gesetzt, verwendet der Filter die QP aus dem Videostream (sofern verfügbar).
Modus
Legen Sie den Schwellenwertmodus fest. Verfügbare Modi sind:
hart
Festlegen des Schwellenwerts.
weich
Weichen Schwellenwert einstellen (besserer Der-Ringing-Effekt, aber wahrscheinlich verschwommener).
mittlere
Legen Sie einen mittleren Schwellenwert fest (gute Ergebnisse, Standard).
Psnr
Ermitteln Sie den durchschnittlichen, maximalen und minimalen PSNR (Peak Signal to Noise Ratio) zwischen zwei
Eingabevideos.
Dieser Filter nimmt in der Eingabe zwei Eingabevideos auf, die erste Eingabe gilt als "Haupt"
Quelle und wird unverändert an die Ausgabe übergeben. Der zweite Eingang dient als "Referenz"
Video zur Berechnung des PSNR.
Beide Videoeingänge müssen dieselbe Auflösung und dasselbe Pixelformat haben, damit dieser Filter funktioniert
korrekt. Es wird auch davon ausgegangen, dass beide Eingänge die gleiche Anzahl von Frames haben, die
eins nach dem anderen verglichen.
Der erhaltene durchschnittliche PSNR wird über das Protokollierungssystem gedruckt.
Der Filter speichert den akkumulierten MSE (Mean Squared Error) jedes Frames und am Ende
der Verarbeitung wird über alle Frames gleichmäßig gemittelt, und die folgende Formel lautet
beantragt, um die PSNR zu erhalten:
PSNR = 10*log10(MAX^2/MSE)
Wobei MAX der Durchschnitt der Maximalwerte jeder Komponente des Bildes ist.
Die Beschreibung der akzeptierten Parameter folgt.
Statistikdatei, f
Wenn angegeben, verwendet der Filter die benannte Datei, um die PSNR jeder Person zu speichern
Rahmen.
Die Datei wird gedruckt, wenn Statistikdatei ausgewählt ist, enthält eine Folge von Schlüssel/Wert-Paaren der
unten stehende Formular Haupt:Wert für jedes verglichene Paar von Frames.
Es folgt eine Beschreibung jedes angezeigten Parameters:
n fortlaufende Nummer des Eingaberahmens, beginnend bei 1
mse_avg
Mittlerer quadratischer Fehler Pixel-für-Pixel-Durchschnittsdifferenz der verglichenen Frames, gemittelt
über alle Bildkomponenten.
mse_y, mse_u, mse_v, mse_r, mse_g, mse_g, mse_a
Mittlerer quadratischer Fehler Pixel-für-Pixel-Durchschnittsdifferenz der verglichenen Frames für die
durch das Suffix angegebene Komponente.
psnr_y, psnr_u, psnr_v, psnr_r, psnr_g, psnr_b, psnr_a
Peak-Signal-Rausch-Verhältnis der verglichenen Frames für die Komponente, die durch die
Suffix.
Beispielsweise:
movie=ref_movie.mpg, setpts=PTS-STARTPTS [main];
[main][ref] psnr="stats_file=stats.log" [out]
In diesem Beispiel wird die verarbeitete Eingabedatei mit der Referenzdatei verglichen
ref_movie.mpg. Das PSNR jedes einzelnen Frames wird gespeichert in stats.log.
Pullup
Pulldown-Umkehrfilter (inverses Telecine), geeignet für gemischte Hard-Telecine,
24000/1001 fps progressive und 30000/1001 fps progressive Inhalte.
Der Pullup-Filter wurde entwickelt, um bei seinen Entscheidungen den zukünftigen Kontext zu nutzen.
Dieser Filter ist zustandslos in dem Sinne, dass er sich nicht an ein zu verfolgendes Muster festhält, aber
es freut sich stattdessen auf die folgenden Felder, um Übereinstimmungen zu identifizieren und neu aufzubauen
progressive Frames.
Um Inhalte mit einer gleichmäßigen Framerate zu produzieren, fügen Sie den fps-Filter nach dem Pullup ein, verwenden Sie
"fps=24000/1001", wenn die Eingabebildrate 29.97fps beträgt, "fps=24" für 30fps und die (seltene)
telecined 25fps-Eingang.
Der Filter akzeptiert die folgenden Optionen:
jl
jr
jt
jb Diese Optionen legen fest, wie viel "Junk" links, rechts, oben und unten ignoriert wird
des Bildes bzw. Links und rechts sind in Einheiten von 8 Pixeln, während oben und
unten sind in Einheiten von 2 Zeilen. Der Standardwert beträgt 8 Pixel auf jeder Seite.
sb Legen Sie die strikten Pausen fest. Wenn Sie diese Option auf 1 setzen, wird die Wahrscheinlichkeit eines Filters verringert
gelegentlich einen nicht übereinstimmenden Frame erzeugen, aber es kann auch eine übermäßige Anzahl verursachen
von Frames, die während High-Motion-Sequenzen ausgelassen werden sollen. Umgekehrt auf -1 . einstellen
wird Filter-Match-Felder einfacher machen. Dies kann bei der Verarbeitung von Videos helfen, wenn
es gibt eine leichte Unschärfe zwischen den Halbbildern, kann aber auch zu Zeilensprung führen
Frames in der Ausgabe. Der Standardwert ist 0.
mp Legen Sie die zu verwendende metrische Ebene fest. Es akzeptiert die folgenden Werte:
l Verwenden Sie die Luma-Ebene.
u Verwenden Sie Chroma-Blau-Ebene.
v Verwenden Sie Chroma-Rot-Ebene.
Diese Option kann so eingestellt werden, dass die Chroma-Ebene anstelle der Standard-Luma-Ebene verwendet wird
Berechnungen des Filters. Dies kann die Genauigkeit bei sehr sauberem Quellmaterial verbessern, aber
wahrscheinlicher wird die Genauigkeit verringert, insbesondere wenn Chroma-Rauschen (Regenbogen
Effekt) oder ein beliebiges Graustufenvideo. Der Hauptzweck der Einstellung mp zu einer Chroma-Ebene ist
um die CPU-Last zu reduzieren und Pullup in Echtzeit auf langsamen Maschinen nutzbar zu machen.
Für beste Ergebnisse (ohne duplizierte Frames in der Ausgabedatei) ist eine Änderung erforderlich
die Ausgabe-Framerate. Um beispielsweise den Telecine-NTSC-Eingang umzukehren:
ffmpeg -i Eingabe -vf pullup -r 24000/1001 ...
qp
Ändern Sie die Videoquantisierungsparameter (QP).
Der Filter akzeptiert die folgende Option:
qp Ausdruck für Quantisierungsparameter einstellen.
Der Ausdruck wird über die eval API ausgewertet und kann unter anderem die
folgende Konstanten:
bekannt
1 wenn Index nicht 129 ist, sonst 0.
qp Sequenzieller Index von -129 bis 128.
Beispiele
· Einige Gleichungen wie:
qp=2+2*sin(PI*qp)
zufällig
Leeren Sie Videoframes aus dem internen Cache von Frames in eine zufällige Reihenfolge. Kein Rahmen ist
verworfen. Inspiriert von frei0r Nervenfilter.
Rahmen
Legen Sie die Größe in der Anzahl der Frames des internen Caches im Bereich von 2 bis 512 fest. Der Standardwert ist 30.
Samen
Seed für Zufallszahlengenerator setzen, muss eine ganze Zahl zwischen 0 und sein
"UINT32_MAX". Wenn nicht angegeben oder explizit auf weniger als 0 gesetzt, wird der Filter
versuchen Sie, einen guten Zufalls-Seed nach bestem Bemühen zu verwenden.
Korn entfernen
Der Removegrain-Filter ist ein räumlicher Entrauscher für progressives Video.
m0 Set-Modus für die erste Ebene.
m1 Set-Modus für die zweite Ebene.
m2 Set-Modus für die dritte Ebene.
m3 Set-Modus für die vierte Ebene.
Der Modusbereich reicht von 0 bis 24. Die Beschreibung jedes Modus folgt:
0 Lassen Sie die Eingabeebene unverändert. Standard.
1 Beschneidet das Pixel mit dem Minimum und Maximum der 8 Nachbarpixel.
2 Beschneidet das Pixel mit dem zweiten Minimum und Maximum der 8 Nachbarpixel.
3 Beschneidet das Pixel mit dem dritten Minimum und Maximum der 8 Nachbarpixel.
4 Beschneidet das Pixel mit dem vierten Minimum und Maximum der 8 Nachbarpixel. Dies
entspricht einem Medianfilter.
5 Liniensensitives Clipping mit minimaler Veränderung.
6 Zeilensensitives Clipping, intermediär.
7 Zeilensensitives Clipping, intermediär.
8 Zeilensensitives Clipping, intermediär.
9 Zeilensensitives Clipping auf einer Zeile, bei der die Nachbarpixel am nächsten sind.
10 Ersetzt das Zielpixel durch den nächsten Nachbarn.
11 [1 2 1] horizontale und vertikale Kernel-Unschärfe.
12 Wie Modus 11.
13 Bob-Modus, interpoliert das obere Halbbild von der Zeile, in der die Nachbarpixel die sind
am nächsten.
14 Bob-Modus, interpoliert das untere Halbbild von der Zeile, in der die Nachbarpixel die sind
am nächsten.
15 Bob-Modus, interpoliert das obere Halbbild. Wie 13, jedoch mit komplizierterer Interpolation
Formel.
16 Bob-Modus, interpoliert unteres Halbbild. Wie 14, aber mit einem komplizierteren
Interpolationsformel.
17 Beschneidet das Pixel mit dem Minimum und Maximum bzw. dem Maximum und Minimum
jedes Paares gegenüberliegender Nachbarpixel.
18 Zeilensensitives Clipping mit gegenüberliegenden Nachbarn, deren größter Abstand zum
aktuelle Pixel ist minimal.
19 Ersetzt das Pixel durch den Durchschnitt seiner 8 Nachbarn.
20 Mittelt die 9 Pixel ([1 1 1] horizontale und vertikale Unschärfe).
21 Beschneidet Pixel unter Verwendung der Mittelwerte des gegenüberliegenden Nachbarn.
22 Wie Modus 21, aber einfacher und schneller.
23 Entfernung kleiner Kanten und Lichthöfe, aber angeblich nutzlos.
24 Ähnlich wie 23.
Logo entfernen
Unterdrücken Sie ein TV-Sender-Logo, indem Sie eine Bilddatei verwenden, um zu bestimmen, aus welchen Pixeln die . besteht
Logo. Es funktioniert, indem es die Pixel, aus denen das Logo besteht, mit benachbarten Pixeln auffüllt.
Der Filter akzeptiert die folgenden Optionen:
Dateiname, f
Legen Sie die Filter-Bitmap-Datei fest, die ein beliebiges Bildformat sein kann, das von libavformat unterstützt wird.
Breite und Höhe der Bilddatei müssen denen des Videostreams entsprechen
verarbeitet.
Pixel im bereitgestellten Bitmap-Bild mit einem Wert von Null werden nicht als Teil des
Logo, Pixel ungleich null werden als Teil des Logos betrachtet. Wenn Sie Weiß (255) für das Logo verwenden
und schwarz (0) für den Rest sind Sie in Sicherheit. Um die Filter-Bitmap zu erstellen, ist es
Es wird empfohlen, eine Bildschirmaufnahme eines schwarzen Rahmens mit sichtbarem Logo zu machen, und dann
unter Verwendung eines Schwellwertfilters gefolgt von dem Erodierfilter ein- oder zweimal.
Kleine Flecken können bei Bedarf manuell behoben werden. Denken Sie daran, wenn Logopixel dies nicht sind
abgedeckt, wird die Filterqualität stark reduziert. Markieren von zu vielen Pixeln als Teil des
Logo tut nicht so weh, aber es erhöht die Unschärfe, die zum Abdecken benötigt wird
über dem Bild und zerstört mehr Informationen als nötig, und zusätzliche Pixel werden
verlangsamen Sie die Dinge auf einem großen Logo.
Wiederholungsfelder
Dieser Filter verwendet das Repeat_field-Flag aus den Video ES-Headern und den Feldern für harte Wiederholungen
basierend auf seinem Wert.
umkehren, umgekehrt
Einen Clip umkehren.
Warnung: Dieser Filter benötigt Speicher, um den gesamten Clip zu puffern, daher wird ein Trimmen empfohlen.
Beispiele
· Nehmen Sie die ersten 5 Sekunden eines Clips auf und kehren Sie ihn um.
trim=Ende=5,rückwärts
drehen
Video um einen beliebigen Winkel im Bogenmaß drehen.
Der Filter akzeptiert die folgenden Optionen:
Eine Beschreibung der optionalen Parameter folgt.
Winkel, a
Legen Sie einen Ausdruck für den Winkel fest, um den das Eingabevideo im Uhrzeigersinn gedreht werden soll,
ausgedrückt als eine Anzahl von Radianten. Ein negativer Wert führt zu einem Gegenuhrzeigersinn
Drehung. Standardmäßig ist es auf "0" eingestellt.
Dieser Ausdruck wird für jeden Frame ausgewertet.
aus_w, ow
Legen Sie den Ausdruck für die Ausgabebreite fest, der Standardwert ist "iw". Dieser Ausdruck wird ausgewertet
nur einmal während der Konfiguration.
aus_h, oh
Legen Sie den Ausdruck für die Ausgabehöhe fest, der Standardwert ist "ih". Dieser Ausdruck wird ausgewertet
nur einmal während der Konfiguration.
bilinear
Aktivieren Sie die bilineare Interpolation, wenn sie auf 1 gesetzt ist, ein Wert von 0 deaktiviert sie. Standardwert ist
1.
Füllfarbe, c
Legen Sie die Farbe fest, die zum Füllen des Ausgabebereichs verwendet wird, der nicht vom gedrehten Bild bedeckt ist. Für die
Allgemeine Syntax dieser Option finden Sie im Abschnitt "Farbe" im Handbuch zu ffmpeg-utils.
Wird der Sonderwert "keine" gewählt, wird kein Hintergrund gedruckt (nützlich für
Beispiel, wenn der Hintergrund nie angezeigt wird).
Standardwert ist "schwarz".
Die Ausdrücke für den Winkel und die Ausgabegröße können folgende Konstanten enthalten und
Funktionen:
n fortlaufende Nummer des Eingaberahmens, beginnend bei 0. Es ist immer NAN vor dem
erster Frame wird gefiltert.
t Zeit in Sekunden des Eingabeframes wird bei der Konfiguration des Filters auf 0 gesetzt. Es
ist immer NAN, bevor der erste Frame gefiltert wird.
hsub
vssub
horizontale und vertikale Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
in_w, iw
in_h, ih
die Breite und Höhe des Eingangsvideos
aus_w, ow
aus_h, oh
die Ausgabebreite und -höhe, d. h. die Größe des aufgefüllten Bereichs, wie durch die
Breite und Höhe Ausdrücke
rotw(a)
roth(a)
die minimale Breite/Höhe, die erforderlich ist, um das um . gedrehte Eingabevideo vollständig zu enthalten
a Bogenmaß.
Diese sind nur verfügbar, wenn die Berechnung der aus_w und aus_h Ausdrücke.
Beispiele
· Drehen Sie den Eingang um PI/6 im Bogenmaß im Uhrzeigersinn:
drehen=PI/6
· Drehen Sie den Eingang um PI/6 im Bogenmaß gegen den Uhrzeigersinn:
rotieren=-PI/6
· Drehen Sie den Eingang um 45 Grad im Uhrzeigersinn:
drehen=45*PI/180
· Wenden Sie eine konstante Drehung mit der Periode T an, ausgehend von einem Winkel von PI/3:
drehen=PI/3+2*PI*t/T
· Bringen Sie die Eingangsvideodrehung in Schwingung mit einer Periode von T Sekunden und einer Amplitude
von A im Bogenmaß:
rotieren=A*sin(2*PI/T*t)
· Drehen Sie das Video, die Ausgabegröße wird so gewählt, dass das gesamte rotierende Eingabevideo
immer vollständig in der Ausgabe enthalten:
rotation='2*PI*t:ow=hypot(iw,ih):oh=ow'
· Drehen Sie das Video, reduzieren Sie die Ausgabegröße, sodass nie ein Hintergrund angezeigt wird:
rotieren=2*PI*t:ow='min(iw,ih)/sqrt(2)':oh=ow:c=none
Befehle
Der Filter unterstützt die folgenden Befehle:
a, Winkel
Stellen Sie den Winkelausdruck ein. Der Befehl akzeptiert die gleiche Syntax des entsprechenden
.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
sab
Wenden Sie die adaptive Unschärfe an.
Der Filter akzeptiert die folgenden Optionen:
luma_radius, lr
Stellen Sie die Luma-Unschärfe-Filterstärke ein, muss ein Wert im Bereich von 0.1 bis 4.0 sein, der Standardwert ist 1.0.
Ein größerer Wert führt zu einem verschwommeneren Bild und zu einer langsameren Verarbeitung.
luma_pre_filter_radius, lpfr
Luma-Vorfilterradius einstellen, muss ein Wert im Bereich von 0.1-2.0 sein, der Standardwert ist
1.0
luma_stärke, ls
Stellen Sie die maximale Luma-Differenz zwischen Pixeln ein, die noch berücksichtigt werden sollen, muss ein Wert in sein
im Bereich von 0.1-100.0, der Standardwert ist 1.0.
Farbradius, cr
Stellen Sie die Stärke des Chroma-Unschärfe-Filters ein, muss ein Wert im Bereich von 0.1 bis 4.0 sein. Ein größerer Wert
führt zu einem verschwommeneren Bild und zu einer langsameren Verarbeitung.
chroma_pre_filter_radius, cfr
Stellen Sie den Chroma-Vorfilterradius ein, muss ein Wert im Bereich von 0.1 bis 2.0 sein.
Chroma_Stärke, cs
Legen Sie die maximale Chroma-Differenz zwischen Pixeln fest, die noch berücksichtigt werden soll, muss ein Wert sein
im Bereich von 0.1-100.0.
Jeder Chroma-Optionswert wird, wenn nicht explizit angegeben, auf das entsprechende Luma gesetzt
Optionswert.
Treppe
Skalieren (Größenänderung) des Eingabevideos mithilfe der Bibliothek libswscale.
Der Skalierungsfilter erzwingt, dass das Seitenverhältnis der Ausgabeanzeige dem der Eingabe entspricht, um
Ändern des Seitenverhältnisses der Ausgabeprobe.
Wenn sich das Eingabebildformat von dem vom nächsten Filter angeforderten Format unterscheidet, wird die
Der Skalierungsfilter konvertiert die Eingabe in das angeforderte Format.
Optionen
Der Filter akzeptiert die folgenden Optionen oder eine der Optionen, die von der
libswscale-Skalierer.
Weitere Informationen finden Sie auch in den ffmpeg-Scaler manuell für die vollständige Liste der Scaler-Optionen.
Breite, w
Höhe, h
Legen Sie den Dimensionsausdruck für das Ausgabevideo fest. Der Standardwert ist die Eingabedimension.
Wenn der Wert 0 ist, wird die Eingabebreite für die Ausgabe verwendet.
Wenn einer der Werte -1 ist, verwendet der Skalierungsfilter einen Wert, der die
Seitenverhältnis des Eingabebilds, berechnet aus der anderen angegebenen Dimension. Wenn
beide sind -1, die Eingabegröße wird verwendet
Wenn einer der Werte -n mit n > 1 ist, verwendet der Skalierungsfilter auch einen Wert, der
behält das Seitenverhältnis des Eingabebildes bei, berechnet aus den anderen angegebenen
Abmessungen. Danach wird jedoch sichergestellt, dass die berechnete Dimension
durch n teilbar und passen Sie den Wert bei Bedarf an.
Unten finden Sie die Liste der akzeptierten Konstanten zur Verwendung im Dimensionsausdruck.
interl
Stellen Sie den Interlacing-Modus ein. Es akzeptiert die folgenden Werte:
1 Interlaced-aware-Skalierung erzwingen.
0 Wenden Sie keine Zeilensprungskalierung an.
-1 Wählen Sie Interlaced Aware Scaling abhängig davon, ob die Quellframes gekennzeichnet sind
als interlaced oder nicht.
Standardwert ist 0.
Fahnen
Setzen Sie die Skalierungsflags von libswscale. Sehen ffmpeg-Scaler manuell für die vollständige Liste der
Werte. Wenn nicht explizit angegeben, wendet der Filter die Standard-Flags an.
Größe, s
Stellen Sie die Videogröße ein. Die Syntax dieser Option finden Sie im "Video Größe" Abschnitt in
ffmpeg-utils manuell.
in_color_matrix
out_color_matrix
Legen Sie den YCbCr-Farbraumtyp für Ein-/Ausgabe fest.
Dies ermöglicht das Überschreiben des automatisch erkannten Werts sowie das Erzwingen eines
spezifischer Wert, der für den Ausgang und den Encoder verwendet wird.
Wenn nicht angegeben, hängt der Farbraumtyp vom Pixelformat ab.
Mögliche Werte:
Auto
Automatisch auswählen.
bt709
Format entspricht der Empfehlung der International Telecommunication Union (ITU)
BT.709.
Fcc Farbraum entsprechend der US-amerikanischen Federal Communications Commission einstellen
(FCC) Code of Federal Regulations (CFR) Titel 47 (2003) 73.682 (a).
bt601
Stellen Sie den Farbraum entsprechend ein:
· Empfehlung des ITU-Funksektors (ITU-R) BT.601
· ITU-R-Empf. BT.470-6 (1998) Systeme B, B1 und G
· Gesellschaft der Film- und Fernsehingenieure (SMPTE) ST 170:2004
smpte240m
Farbraum entsprechend SMPTE ST 240:1999 einstellen.
im Bereich
out_range
Legen Sie den YCbCr-Abtastbereich für den Ein-/Ausgang fest.
Dies ermöglicht das Überschreiben des automatisch erkannten Werts sowie das Erzwingen eines
spezifischer Wert, der für den Ausgang und den Encoder verwendet wird. Wenn nicht angegeben, hängt die Reichweite von
das Pixelformat. Mögliche Werte:
Auto
Automatisch auswählen.
jpeg/voll/pc
Vollen Bereich einstellen (0-255 bei 8-Bit-Luma).
MPEG/TV
Stellen Sie den "MPEG"-Bereich (16-235 bei 8-Bit-Luma) ein.
force_original_aspect_ratio
Aktivieren Sie bei Bedarf das Verringern oder Erhöhen der Breite oder Höhe des Ausgabevideos, um die
ursprüngliches Seitenverhältnis. Mögliche Werte:
deaktivieren
Skalieren Sie das Video wie angegeben und deaktivieren Sie diese Funktion.
verringern
Die Abmessungen des Ausgabevideos werden bei Bedarf automatisch verringert.
Energie
Die Abmessungen des Ausgabevideos werden bei Bedarf automatisch erhöht.
Ein nützliches Beispiel für diese Option ist, wenn Sie das Maximum eines bestimmten Geräts kennen
erlaubte Auflösung, können Sie dies verwenden, um das Ausgabevideo darauf zu begrenzen, während
das Seitenverhältnis beibehalten. Gerät A ermöglicht beispielsweise die Wiedergabe von 1280 x 720 und Ihr
Video ist 1920x800. Verwenden Sie diese Option (verringern Sie sie) und geben Sie 1280 x 720 auf an
die Befehlszeile macht die Ausgabe 1280x533.
Bitte beachten Sie, dass dies etwas anderes ist als die Angabe von -1 für w or hdu immer noch
müssen Sie die Ausgabeauflösung angeben, damit diese Option funktioniert.
Die Werte der w und h Optionen sind Ausdrücke, die die folgenden Konstanten enthalten:
in_w
in_h
Die Eingabebreite und -höhe
iw
ih Das sind die gleichen wie in_w und in_h.
aus_w
aus_h
Breite und Höhe der Ausgabe (skaliert)
ow
oh Das sind die gleichen wie aus_w und aus_h
a Das Gleiche wie iw / ih
sar Seitenverhältnis des Eingabebeispiels
geben Das Seitenverhältnis der Eingabeanzeige. Berechnet aus "(iw / ih) * sar".
hsub
vssub
horizontale und vertikale Eingabe-Chroma-Subsample-Werte. Zum Beispiel für das Pixel
Format "yuv422p" hsub ist 2 und vssub ist 1.
ohsub
ovsub
horizontale und vertikale Ausgangs-Chroma-Subsample-Werte. Zum Beispiel für das Pixel
Format "yuv422p" hsub ist 2 und vssub ist 1.
Beispiele
· Skalieren Sie das Eingangsvideo auf eine Größe von 200x100
Maßstab=b=200:h=100
Dies ist äquivalent zu:
Maßstab=200:100
oder:
Maßstab=200x100
· Geben Sie ein Größenkürzel für die Ausgabegröße an:
Maßstab=qcif
was auch geschrieben werden kann als:
Maßstab=Größe=qcif
· Skalieren Sie die Eingabe auf 2x:
Maßstab=w=2*iw:h=2*ih
· Das obige ist dasselbe wie:
Maßstab=2*Zoll_B:2*Zoll_H
· Skalieren Sie den Eingang mit erzwungener Zeilensprungskalierung auf 2x:
Skala=2*iw:2*ih:interl=1
· Skalieren Sie die Eingabe auf die halbe Größe:
Skala=w=iw/2:h=ih/2
· Erhöhen Sie die Breite und stellen Sie die Höhe auf dieselbe Größe ein:
Maßstab=3/2*iw:ow
· Suche nach griechischer Harmonie:
Maßstab=iw:1/PHI*iw
Maßstab=ih*PHI:ih
· Erhöhen Sie die Höhe und stellen Sie die Breite auf 3/2 der Höhe ein:
Skala=w=3/2*oh:h=3/5*ih
· Erhöhen Sie die Größe, sodass die Größe ein Vielfaches der Chroma-Subsample-Werte ist:
scale="trunc(3/2*iw/hsub)*hsub:trunc(3/2*ih/vsub)*vsub"
· Erhöhen Sie die Breite auf maximal 500 Pixel und behalten Sie dabei das gleiche Seitenverhältnis wie das
Eingang:
scale=w='min(500\, iw*3/2):h=-1'
Befehle
Dieser Filter unterstützt die folgenden Befehle:
Breite, w
Höhe, h
Legen Sie den Dimensionsausdruck für das Ausgabevideo fest. Der Befehl akzeptiert die gleiche Syntax wie der
entsprechende Option.
Wenn der angegebene Ausdruck nicht gültig ist, wird sein aktueller Wert beibehalten.
scale2ref
Skalieren (Größenänderung) des Eingangsvideos basierend auf einem Referenzvideo.
Siehe den Skalierungsfilter für verfügbare Optionen, scale2ref unterstützt dasselbe, verwendet aber die
Referenzvideo anstelle des Haupteingangs als Basis.
Beispiele
· Skalieren Sie einen Untertitelstream, um die Größe des Hauptvideos anzupassen, bevor Sie ihn überlagern
'scale2ref[b][a][a][b]overlay'
separateFelder
Die "separatefields" nehmen einen Frame-basierten Videoeingang und teilen jeden Frame in seine
Komponentenfelder, wodurch ein neuer Clip mit halber Höhe mit doppelter und doppelter Bildrate erzeugt wird
die Frameanzahl.
Dieser Filter verwendet Halbbild-Dominanz-Informationen im Rahmen, um zu entscheiden, welche von jedem Paar von
Felder, die in der Ausgabe an erster Stelle stehen. Wenn es falsch wird, verwenden Sie Setfeld vorher filtern
Filter "getrennte Felder".
setdar, setar
Der "setdar"-Filter legt das Anzeige-Seitenverhältnis für das Filterausgabevideo fest.
Dies geschieht durch Ändern des angegebenen Seitenverhältnisses des Samples (auch bekannt als Pixel) gemäß der
folgende Gleichung:
= / *
Denken Sie daran, dass der Filter "setdar" die Pixelabmessungen des Videos nicht ändert.
Rahmen. Außerdem kann das durch diesen Filter eingestellte Anzeige-Seitenverhältnis durch spätere Filter geändert werden
in der Filterkette, zB bei Skalierung oder wenn ein anderer "setdar" oder ein "setsar" Filter ist
angewendet.
Der "setsar"-Filter legt das Sample-Seitenverhältnis (auch bekannt als Pixel) für das Filterausgangsvideo fest.
Beachten Sie, dass infolge der Anwendung dieses Filters der Ausgabeanzeigeaspekt
Das Verhältnis ändert sich gemäß der obigen Gleichung.
Beachten Sie, dass das vom Filter "setsar" eingestellte Seitenverhältnis des Samples geändert werden kann durch
spätere Filter in der Filterkette, zB wenn ein anderer "setsar" oder ein "setdar" Filter ist
angewendet.
Es akzeptiert die folgenden Parameter:
r, Verhältnis, geben ("setdar" nur), sar ("setsar" nur)
Stellen Sie das vom Filter verwendete Seitenverhältnis ein.
Der Parameter kann eine Gleitkommazahlzeichenfolge, ein Ausdruck oder eine Zeichenfolge der
unten stehende Formular num:am, Wobei num und am sind Zähler und Nenner des Seitenverhältnisses.
Wird der Parameter nicht angegeben, wird der Wert "0" angenommen. Falls das Formular
"num:am" verwendet wird, sollte das Zeichen ":" mit Escapezeichen versehen werden.
max Legen Sie den maximalen ganzzahligen Wert fest, der zum Ausdrücken von Zähler und Nenner verwendet werden soll, wenn
Reduzierung des ausgedrückten Seitenverhältnisses auf ein rationales. Der Standardwert ist 100.
Der Parameter sar ist ein Ausdruck, der die folgenden Konstanten enthält:
E, PI, PHI
Dies sind Näherungswerte für die mathematischen Konstanten e (Eulersche Zahl), pi
(griechisch pi) und phi (der goldene Schnitt).
w, h
Die Eingabebreite und -höhe.
a Das sind die gleichen wie w / h.
sar Das Seitenverhältnis des Eingabebeispiels.
geben Das Seitenverhältnis der Eingabeanzeige. Es ist das gleiche wie (w / h) * sar.
hsub, vssub
Horizontale und vertikale Chroma-Subsample-Werte. Zum Beispiel für das Pixelformat
"yuv422p" hsub ist 2 und vssub ist 1.
Beispiele
· Um das Anzeige-Seitenverhältnis in 16:9 zu ändern, geben Sie eine der folgenden Optionen an:
setdar=dar=1.77777
setdar=dar=16/9
setdar=dar=1.77777
· Um das Seitenverhältnis des Samples auf 10:11 zu ändern, geben Sie Folgendes an:
setar=sar=10/11
· Um ein Anzeige-Seitenverhältnis von 16:9 einzustellen und einen maximalen ganzzahligen Wert von 1000 Zoll anzugeben
Um das Seitenverhältnis zu reduzieren, verwenden Sie den Befehl:
setdar=Verhältnis=16/9:max=1000
Setfeld
Kraftfeld für das Ausgabevideobild.
Der Filter "setfield" markiert das Interlace-Typ-Feld für die Ausgabeframes. Es tut nicht
den Eingaberahmen ändern, aber nur die entsprechende Eigenschaft festlegen, die sich darauf auswirkt, wie die
Frame wird durch folgende Filter behandelt (zB "fieldorder" oder "yadif").
Der Filter akzeptiert die folgenden Optionen:
Modus
Verfügbare Werte sind:
Auto
Behalten Sie dieselbe Feldeigenschaft bei.
bff Markieren Sie den Rahmen als Bottom-Field-First.
tff Markieren Sie den Rahmen als Top-Field-First.
prog
Markieren Sie den Rahmen als progressiv.
show
Zeigen Sie eine Zeile mit verschiedenen Informationen für jeden eingegebenen Videoframe an. Das Eingangsvideo ist
Nicht modifiziert.
Die angezeigte Zeile enthält eine Folge von Schlüssel/Wert-Paaren der Form Haupt:Wert.
In der Ausgabe werden folgende Werte angezeigt:
n Die (laufende) Nummer des Eingabeframes, beginnend bei 0.
pts Der Präsentations-Zeitstempel des Eingaberahmens, ausgedrückt als Anzahl der Zeitbasis
Einheiten. Die Zeitbasiseinheit hängt vom Filtereingangspad ab.
pts_time
Der Präsentations-Zeitstempel des Eingabeframes, ausgedrückt in Sekunden.
Post Die Position des Frames im Eingabestream oder -1, wenn diese Information . ist
nicht verfügbar und/oder bedeutungslos (zum Beispiel bei synthetischem Video).
fmt Der Name des Pixelformats.
sar Das Beispiel-Seitenverhältnis des Eingabeframes, ausgedrückt in der Form num/am.
s Die Größe des Eingabeframes. Die Syntax dieser Option finden Sie im "Video Größe"
Abschnitt in ffmpeg-utils manuell.
i Die Art des Zeilensprungmodus ("P" für "progressiv", "T" für oberes Halbbild zuerst, "B" für
unteres Feld zuerst).
iskey
Dies ist 1, wenn das Bild ein Schlüsselbild ist, ansonsten 0.
tippe
Der Bildtyp des Eingabebildes ("I" für ein I-Bild, "P" für ein P-Bild, "B" für a
B-Rahmen oder "?" für einen unbekannten Typ). Beachten Sie auch die Dokumentation der
"AVPictureType"-Enum und der in . definierten Funktion "av_get_picture_type_char"
libavutil/avutil.h.
Prüfsumme
Die Adler-32-Prüfsumme (in hexadezimal gedruckt) aller Ebenen des Eingaberahmens.
plane_checksum
Die Adler-32-Prüfsumme (in hexadezimal gedruckt) jeder Ebene des Eingaberahmens,
ausgedrückt in der Form "[c0 c1 c2 c3]".
Showpalette
Zeigt die 256-Farben-Palette jedes Frames an. Dieser Filter ist nur relevant für pal8 Pixel
Rahmen formatieren.
Es akzeptiert die folgende Option:
s Legen Sie die Größe des Felds fest, das verwendet wird, um einen Palettenfarbeintrag darzustellen. Standard ist 30 (für
eine "30x30"-Pixelbox).
Shuffleplanes
Videoebenen neu anordnen und/oder duplizieren.
Es akzeptiert die folgenden Parameter:
map0
Der Index der Eingabeebene, die als erste Ausgabeebene verwendet werden soll.
map1
Der Index der Eingabeebene, die als zweite Ausgabeebene verwendet werden soll.
map2
Der Index der Eingabeebene, die als dritte Ausgabeebene verwendet werden soll.
map3
Der Index der Eingabeebene, die als vierte Ausgabeebene verwendet werden soll.
Die erste Ebene hat den Index 0. Standardmäßig bleibt die Eingabe unverändert.
Vertauschen Sie die zweite und dritte Ebene der Eingabe:
ffmpeg -i EINGABE -vf shuffleplanes=0:2:1:3 AUSGABE
Signalstatistiken
Bewerten Sie verschiedene visuelle Metriken, die bei der Ermittlung von Problemen im Zusammenhang mit dem . helfen
Digitalisierung analoger Videomedien.
Standardmäßig protokolliert der Filter diese Metadatenwerte:
YMIN
Zeigen Sie den minimalen Y-Wert an, der im Eingaberahmen enthalten ist. Ausgedrückt im Bereich von
[0-255].
GELB
Zeigen Sie den Y-Wert beim 10%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt in Reichweite
von [0-255].
YAVG
Zeigen Sie den durchschnittlichen Y-Wert innerhalb des Eingaberahmens an. Ausgedrückt im Bereich von [0-255].
JHOCH
Zeigen Sie den Y-Wert beim 90%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt in Reichweite
von [0-255].
YMAX
Zeigen Sie den maximalen Y-Wert an, der innerhalb des Eingaberahmens enthalten ist. Ausgedrückt im Bereich von
[0-255].
UMIN
Zeigen Sie den minimalen U-Wert an, der im Eingaberahmen enthalten ist. Ausgedrückt im Bereich von
[0-255].
ULOW
Zeigen Sie den U-Wert beim 10%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt in Reichweite
von [0-255].
UAVG
Zeigen Sie den durchschnittlichen U-Wert innerhalb des Eingaberahmens an. Ausgedrückt im Bereich von [0-255].
UHOCH
Zeigen Sie den U-Wert beim 90%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt in Reichweite
von [0-255].
Umax
Zeigen Sie den maximalen U-Wert an, der innerhalb des Eingaberahmens enthalten ist. Ausgedrückt im Bereich von
[0-255].
VMIN
Zeigen Sie den minimalen V-Wert an, der im Eingaberahmen enthalten ist. Ausgedrückt im Bereich von
[0-255].
VLOW
Zeigen Sie den V-Wert beim 10%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt in Reichweite
von [0-255].
VAVG
Zeigen Sie den durchschnittlichen V-Wert innerhalb des Eingaberahmens an. Ausgedrückt im Bereich von [0-255].
VHOCH
Zeigen Sie den V-Wert beim 90%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt in Reichweite
von [0-255].
VMAX
Zeigen Sie den maximalen V-Wert an, der innerhalb des Eingaberahmens enthalten ist. Ausgedrückt im Bereich von
[0-255].
SATMIN
Zeigt den minimalen Sättigungswert an, der im Eingabebild enthalten ist. Ausgedrückt
Bereich von [0-~181.02].
SATLOW
Zeigen Sie den Sättigungswert beim 10%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt
im Bereich von [0-~181.02].
SATAVG
Zeigen Sie den durchschnittlichen Sättigungswert innerhalb des Eingaberahmens an. Ausgedrückt im Bereich von
[0-~181.02].
SATHIG
Zeigen Sie den Sättigungswert beim 90%-Perzentil innerhalb des Eingaberahmens an. Ausgedrückt
im Bereich von [0-~181.02].
SATMAX
Zeigen Sie den maximalen Sättigungswert an, der innerhalb des Eingaberahmens enthalten ist. Ausgedrückt
Bereich von [0-~181.02].
HUEMED
Zeigen Sie den Medianwert für den Farbton innerhalb des Eingaberahmens an. Ausgedrückt im Bereich von
[0-360].
HUEAVG
Zeigen Sie den Durchschnittswert für den Farbton innerhalb des Eingaberahmens an. Ausgedrückt im Bereich von
[0-360].
YDIF
Zeigen Sie den Durchschnitt der Abtastwertdifferenz zwischen allen Werten der Y-Ebene in . an
den aktuellen Frame und die entsprechenden Werte des vorherigen Eingabeframes. Ausgedrückt
Bereich von [0-255].
UDIF
Zeigen Sie den Durchschnitt der Abtastwertdifferenz zwischen allen Werten der U-Ebene in . an
den aktuellen Frame und die entsprechenden Werte des vorherigen Eingabeframes. Ausgedrückt
Bereich von [0-255].
VDIF
Zeigen Sie den Durchschnitt der Abtastwertdifferenz zwischen allen Werten der V-Ebene in . an
den aktuellen Frame und die entsprechenden Werte des vorherigen Eingabeframes. Ausgedrückt
Bereich von [0-255].
Der Filter akzeptiert die folgenden Optionen:
Zustand
Zustand spezifizieren eine zusätzliche Form der Bildanalyse. Video ausgeben mit dem
angegebenen Pixeltyp hervorgehoben.
Beide Optionen akzeptieren die folgenden Werte:
Alles
Identifikation temporäre Ausreißer Pixel. EIN temporäre Ausreißer ist ein Pixel anders als das
benachbarte Pixel des gleichen Halbbildes. Beispiele für zeitliche Ausreißer sind die
Folgen von Videoausfällen, Kopfverstopfungen oder Bandverfolgungsproblemen.
vrep
Identifikation vertikal Linie Wiederholung. Vertikale Zeilenwiederholung umfasst ähnliche Zeilen
von Pixeln innerhalb eines Frames. In Born-Digital-Video ist die vertikale Zeilenwiederholung
häufig, aber dieses Muster ist ungewöhnlich bei Videos, die von einer analogen Quelle digitalisiert wurden.
Wenn es in einem Video auftritt, das aus der Digitalisierung einer analogen Quelle resultiert, ist es
kann eine Verbergung vor einem Ausfallkompensator anzeigen.
bringen
Identifizieren Sie Pixel, die außerhalb des zulässigen Sendebereichs liegen.
Farbe, Farbe, c
Legen Sie die Hervorhebungsfarbe für die fest Möglichkeit. Die Standardfarbe ist gelb.
Beispiele
· Ausgabedaten verschiedener Videometriken:
ffprobe -f lavfi movie=example.mov,signalstats="stat=tout+vrep+brng" -show_frames
· Ausgabe spezifischer Daten über die Minimal- und Maximalwerte der Y-Ebene pro Frame:
ffprobe -f lavfi movie=example.mov,signalstats -show_entries frame_tags=lavfi.signalstats.YMAX,lavfi.signalstats.YMIN
· Video wiedergeben, während Pixel, die außerhalb des Sendebereichs liegen, rot hervorgehoben werden.
ffplay example.mov -vf signalstats="out=brng:color=red"
· Playback-Video mit signalstats-Metadaten, die über den Rahmen gezeichnet werden.
ffplay example.mov -vf signalstats=stat=brng+vrep+tout,drawtext=fontfile=FreeSerif.ttf:textfile=signalstat_drawtext.txt
Der Inhalt der im Befehl verwendeten signalstat_drawtext.txt ist:
Zeit %{pts:hms}
Y (%{metadata:lavfi.signalstats.YMIN}-%{metadata:lavfi.signalstats.YMAX})
U (%{metadata:lavfi.signalstats.UMIN}-%{metadata:lavfi.signalstats.UMAX})
V (%{metadata:lavfi.signalstats.VMIN}-%{metadata:lavfi.signalstats.VMAX})
Sättigungsmaximum: %{metadata:lavfi.signalstats.SATMAX}
intelligente Unschärfe
Verwischen Sie das Eingabevideo, ohne die Umrisse zu beeinträchtigen.
Es akzeptiert die folgenden Optionen:
luma_radius, lr
Stellen Sie den Luma-Radius ein. Der Optionswert muss eine Gleitkommazahl im Bereich [0.1,5.0] sein.
die die Varianz des Gauss-Filters angibt, der verwendet wird, um das Bild zu verwischen (langsamer, wenn
größer). Der Standardwert ist 1.0.
luma_stärke, ls
Stellen Sie die Luma-Stärke ein. Der Optionswert muss eine Gleitkommazahl im Bereich [-1.0,1.0] sein.
das konfiguriert die Unschärfe. Ein in [0.0,1.0] enthaltener Wert verwischt das Bild
wohingegen ein in [-1.0,0.0] enthaltener Wert das Bild schärfer macht. Der Standardwert ist 1.0.
luma_threshold, lt
Legen Sie den Luma-Schwellenwert fest, der als Koeffizient verwendet wird, um zu bestimmen, ob ein Pixel
verschwommen oder nicht. Der Optionswert muss eine ganze Zahl im Bereich [-30,30] sein. Ein Wert von
0 filtert das gesamte Bild, ein in [0,30] enthaltener Wert filtert flache Bereiche und a
Der in [-30,0] enthaltene Wert filtert Kanten. Der Standardwert ist 0.
Farbradius, cr
Stellen Sie den Chroma-Radius ein. Der Optionswert muss eine Gleitkommazahl im Bereich [0.1,5.0] sein.
die die Varianz des Gauss-Filters angibt, der verwendet wird, um das Bild zu verwischen (langsamer, wenn
größer). Der Standardwert ist 1.0.
Chroma_Stärke, cs
Stellen Sie die Chroma-Stärke ein. Der Optionswert muss eine Gleitkommazahl im Bereich . sein
[-1.0,1.0] konfiguriert die Unschärfe. Ein in [0.0,1.0] enthaltener Wert verwischt die
Bild, wohingegen ein in [-1.0,0.0] enthaltener Wert das Bild schärfer macht. Standardwert ist
1.0
chroma_threshold, ct
Legen Sie den Chroma-Schwellenwert fest, der als Koeffizient verwendet wird, um zu bestimmen, ob ein Pixel
verschwommen oder nicht. Der Optionswert muss eine ganze Zahl im Bereich [-30,30] sein. Ein Wert von
0 filtert das gesamte Bild, ein in [0,30] enthaltener Wert filtert flache Bereiche und a
Der in [-30,0] enthaltene Wert filtert Kanten. Der Standardwert ist 0.
Wenn eine Chroma-Option nicht explizit gesetzt ist, wird der entsprechende Luma-Wert gesetzt.
sim
Rufen Sie die SSIM (Structural SIMilarity Metric) zwischen zwei Eingabevideos ab.
Dieser Filter nimmt in der Eingabe zwei Eingabevideos auf, die erste Eingabe gilt als "Haupt"
Quelle und wird unverändert an die Ausgabe übergeben. Der zweite Eingang dient als "Referenz"
Video zum Berechnen der SSIM.
Beide Videoeingänge müssen dieselbe Auflösung und dasselbe Pixelformat haben, damit dieser Filter funktioniert
korrekt. Es wird auch davon ausgegangen, dass beide Eingänge die gleiche Anzahl von Frames haben, die
eins nach dem anderen verglichen.
Der Filter speichert die berechnete SSIM jedes Frames.
Die Beschreibung der akzeptierten Parameter folgt.
Statistikdatei, f
Wenn angegeben, verwendet der Filter die benannte Datei, um die SSIM jeder Person zu speichern
Rahmen.
Die Datei wird gedruckt, wenn Statistikdatei ausgewählt ist, enthält eine Folge von Schlüssel/Wert-Paaren der
unten stehende Formular Haupt:Wert für jedes verglichene Paar von Frames.
Es folgt eine Beschreibung jedes angezeigten Parameters:
n fortlaufende Nummer des Eingaberahmens, beginnend bei 1
Y, U, V, R, G, B
SSIM der verglichenen Frames für die durch das Suffix angegebene Komponente.
Alle SSIM der verglichenen Frames für den gesamten Frame.
dB Wie oben, jedoch in dB-Darstellung.
Beispielsweise:
movie=ref_movie.mpg, setpts=PTS-STARTPTS [main];
[main][ref] ssim="stats_file=stats.log" [out]
In diesem Beispiel wird die verarbeitete Eingabedatei mit der Referenzdatei verglichen
ref_movie.mpg. Die SSIM jedes einzelnen Frames wird gespeichert in stats.log.
Ein weiteres Beispiel mit psnr und ssim gleichzeitig:
ffmpeg -i main.mpg -i ref.mpg -lavfi "ssim;[0:v][1:v]psnr" -f null -
stereo3d
Konvertieren Sie zwischen verschiedenen stereoskopischen Bildformaten.
Die Filter akzeptieren die folgenden Optionen:
in Stellen Sie das stereoskopische Bildformat der Eingabe ein.
Verfügbare Werte für Eingabebildformate sind:
sbsl
nebeneinander parallel (linkes Auge links, rechtes Auge rechts)
jdn
nebeneinander Fadenkreuz (rechtes Auge links, linkes Auge rechts)
sbs2l
nebeneinander parallel mit Halbseitenauflösung (linkes Auge links, rechtes Auge rechts)
sbs2r
paralleles Fadenkreuz mit Halbseitenauflösung (rechtes Auge links, linkes Auge rechts)
abl oben-unten (linkes Auge oben, rechtes Auge unten)
April oben-unten (rechtes Auge oben, linkes Auge unten)
ab2l
oben-unten mit halber Höhenauflösung (linkes Auge oben, rechtes Auge unten)
ab2r
oben-unten mit halber Höhenauflösung (rechtes Auge oben, linkes Auge unten)
al abwechselnde Bilder (linkes Auge zuerst, rechtes Auge dann)
ar abwechselnde Bilder (rechtes Auge zuerst, linkes Auge dann)
Standardwert ist sbsl.
Stellen Sie das stereoskopische Bildformat der Ausgabe ein.
Verfügbare Werte für Ausgabebildformate sind alle Eingabeformate sowie:
Arbg
Anaglyphe Rot/Blaugrau (Rotfilter am linken Auge, Blaufilter am rechten Auge)
Arg
Anaglyphe Rot/Grüngrau (Rotfilter am linken Auge, Grünfilter am rechten Auge)
Bogen
Anaglyphenrot/Cyangrau (Rotfilter am linken Auge, Cyanfilter am rechten Auge)
Bogen
Anaglyphe Rot/Cyan halbfarbig (Rotfilter am linken Auge, Cyanfilter am rechten Auge)
arcc
Anaglyphenfarbe Rot/Cyan (Rotfilter am linken Auge, Cyanfilter am rechten Auge)
arcd
Anaglyphe Rot/Cyan Farbe optimiert mit der kleinsten Quadrate Projektion von Dubois (Rot
Filter auf dem linken Auge, Cyan-Filter auf dem rechten Auge)
agmg
Anaglyphengrün/Magentagrau (grüner Filter am linken Auge, Magentafilter am rechten
Auge)
ähm
Anaglyphe grün/magenta halbfarbig (grüner Filter am linken Auge, Magenta Filter an
rechtes Auge)
aggm
Anaglyphe grün/magentafarben (grüner Filter auf dem linken Auge, Magenta Filter auf dem rechten)
Auge)
Hauptversammlung
Anaglyphenfarbe Grün/Magenta, optimiert mit der kleinsten Quadrate Projektion von dubois
(grüner Filter am linken Auge, Magentafilter am rechten Auge)
aybg
Anaglyphe Gelb/Blaugrau (Gelbfilter am linken Auge, Blaufilter am rechten Auge)
Aybh
Anaglyphe gelb/blau halbfarbig (Gelbfilter am linken Auge, Blaufilter rechts
Auge)
aybc
Anaglyphe gelb/blau gefärbt (Gelbfilter am linken Auge, Blaufilter am rechten Auge)
aybd
Anaglyphenfarbe gelb/blau optimiert mit der kleinsten Quadrate Projektion von dubois
(Gelbfilter am linken Auge, Blaufilter am rechten Auge)
irl verschachtelte Reihen (linkes Auge hat obere Reihe, rechtes Auge beginnt mit der nächsten Reihe)
irr verschachtelte Reihen (rechtes Auge hat obere Reihe, linkes Auge beginnt mit nächster Reihe)
ml Mono-Ausgang (nur linkes Auge)
mr Mono-Ausgang (nur rechtes Auge)
Standardwert ist arcd.
Beispiele
· Konvertieren des Eingangsvideos von nebeneinander parallel in ein anaglyphisches Gelb/Blau-Dubois:
stereo3d=sbsl:aybd
· Konvertieren des Eingangsvideos von oben unten (linkes Auge oben, rechtes Auge unten) in nebeneinander
Fadenkreuz.
stereo3d=abl:sbsr
spp
Wenden Sie einen einfachen Nachbearbeitungsfilter an, der das Bild mehrmals komprimiert und dekomprimiert
(oder - im Fall von qualitativ hochwertiges Stufe 6 - alle) verschiebt und durchschnittlich die Ergebnisse.
Der Filter akzeptiert die folgenden Optionen:
qualitativ hochwertiges
Qualität einstellen. Diese Option definiert die Anzahl der Ebenen für die Mittelwertbildung. Es akzeptiert ein
Ganzzahl im Bereich 0-6. Bei 0 hat der Filter keine Wirkung. Ein Wert von 6
bedeutet die höhere Qualität. Für jede Erhöhung dieses Wertes sinkt die Geschwindigkeit um einen Faktor
von ungefähr 2. Der Standardwert ist 3.
qp Erzwinge einen konstanten Quantisierungsparameter. Wenn nicht gesetzt, verwendet der Filter die QP von
den Videostream (sofern verfügbar).
Modus
Legen Sie den Schwellenwertmodus fest. Verfügbare Modi sind:
hart
Festlegen des Schwellenwerts (Standard).
weich
Weichen Schwellenwert einstellen (besserer Der-Ringing-Effekt, aber wahrscheinlich verschwommener).
use_bframe_qp
Aktivieren Sie die Verwendung des QP von den B-Frames, wenn auf 1 gesetzt. Die Verwendung dieser Option kann zu
flackern, da die B-Frames oft größere QP haben. Der Standardwert ist 0 (nicht aktiviert).
Untertitel
Zeichnen Sie mit der Libass-Bibliothek Untertitel über das Eingabevideo.
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie FFmpeg mit "--enable-libass" konfigurieren.
Dieser Filter erfordert auch einen Build mit libavcodec und libavformat, um das übergebene zu konvertieren
Untertiteldatei in das ASS-Untertitelformat (Advanced Substation Alpha).
Der Filter akzeptiert die folgenden Optionen:
Dateiname, f
Legen Sie den Dateinamen der Untertiteldatei zum Lesen fest. Es muss angegeben werden.
Originalgröße
Geben Sie die Größe des Originalvideos an, das Video, für das die ASS-Datei komponiert wurde.
Die Syntax dieser Option finden Sie im "Video Größe" Abschnitt in ffmpeg-utils
manuell. Aufgrund eines Fehldesigns in der ASS-Seitenverhältnisarithmetik ist dies notwendig, um
Skalieren Sie die Schriftarten richtig, wenn das Seitenverhältnis geändert wurde.
Schriftendir
Legen Sie einen Verzeichnispfad fest, der Schriftarten enthält, die vom Filter verwendet werden können. Diese Schriftarten
wird zusätzlich zu dem verwendet, was der Schriftartenanbieter verwendet.
charenz
Legen Sie die Zeichencodierung für die Eingabe von Untertiteln fest. Nur "Untertitel"-Filter. Nur sinnvoll, wenn nicht
UTF-8.
stream_index, si
Untertitel-Stream-Index festlegen. Nur "Untertitel"-Filter.
force_style
Überschreiben Sie die Standardstil- oder Skriptinfo-Parameter der Untertitel. Es akzeptiert eine Zeichenfolge
das ASS-Format enthält "KEY=VALUE" Paare, die durch "," getrennt sind.
Wenn der erste Schlüssel nicht angegeben ist, wird angenommen, dass der erste Wert den . angibt
Dateinamen.
Zum Beispiel, um die Datei zu rendern sub.srt Verwenden Sie oben auf dem Eingabevideo den Befehl:
Untertitel=sub.srt
was äquivalent ist zu:
Untertitel=Dateiname=sub.srt
So rendern Sie den Standard-Untertitel-Stream aus einer Datei video.mkvVerwenden Sie:
Untertitel=video.mkv
Um den zweiten Untertitel-Stream aus dieser Datei zu rendern, verwenden Sie:
untertitel=video.mkv:si=1
So lassen Sie die Untertitel streamen von sub.srt erscheinen in transparentem Grün "DejaVu Serif", verwenden Sie:
subtitles=sub.srt:force_style='FontName=DejaVu Serif,PrimaryColour=&HAA00FF00'
super2xsai
Skalieren Sie die Eingabe um das 2-fache und glätten Sie sie mit der Super2xSaI-Pixelgrafik (Scale and Interpolate)
Skalierungsalgorithmus.
Nützlich, um Pixel-Art-Bilder zu vergrößern, ohne die Schärfe zu verringern.
tauschuv
U- und V-Ebene tauschen.
Telecine
Wenden Sie den Telecine-Prozess auf das Video an.
Dieser Filter akzeptiert die folgenden Optionen:
erstes_feld
oben, t
oberstes Feld zuerst
Unterseite, b
unteres Feld zuerst Der Standardwert ist "top".
Anleitungen
Eine Zahlenfolge, die das Pulldown-Muster darstellt, das Sie anwenden möchten. Der Standard
Wert ist 23.
Einige typische Muster:
NTSC-Ausgang (30i):
27.5p: 32222
24p: 23 (klassisch)
24p: 2332 (bevorzugt)
20p: 33
18p: 334
16p: 3444
PAL-Ausgang (25i):
27.5p: 12222
24p: 222222222223 ("Euro-Pulldown")
16.67p: 33
16p: 33333334
Daumennagel
Wählen Sie den repräsentativsten Frame in einer gegebenen Sequenz aufeinanderfolgender Frames aus.
Der Filter akzeptiert die folgenden Optionen:
n Legen Sie die zu analysierende Frame-Stapelgröße fest; in einer Reihe von n Frames, der Filter wählt einen aus
von ihnen und bearbeiten Sie dann die nächste Charge von n Rahmen bis zum Schluss. Standard ist 100.
Da der Filter die gesamte Frame-Sequenz verfolgt, ist ein größeres n Wert ergibt
einen höheren Speicherverbrauch, daher wird ein hoher Wert nicht empfohlen.
Beispiele
· Extrahieren Sie ein Bild alle 50 Frames:
Vorschaubild = 50
· Vollständiges Beispiel einer Thumbnail-Erstellung mit ffmpeg:
ffmpeg -i in.avi -vf thumbnail,scale=300:200 -frames:v 1 out.png
Kachel
Bringen Sie mehrere aufeinanderfolgende Frames zusammen.
Der Filter akzeptiert die folgenden Optionen:
Layout
Legen Sie die Rastergröße fest (dh die Anzahl der Zeilen und Spalten). Für die Syntax davon
Option, aktivieren Sie die "Video Größe" Abschnitt in ffmpeg-utils manuell.
nb_frames
Legen Sie die maximale Anzahl von Frames fest, die im angegebenen Bereich gerendert werden sollen. Es muss kleiner sein als oder
gleich wxh. Der Standardwert ist 0, was bedeutet, dass der gesamte Bereich verwendet wird.
Marge
Legen Sie den äußeren Randrand in Pixel fest.
Polsterung
Legen Sie die Dicke des inneren Rands fest (dh die Anzahl der Pixel zwischen den Bildern). Für mehr
erweiterte Fülloptionen (z. B. unterschiedliche Werte für die Kanten) finden Sie in der
Videofilter auffüllen.
Farbe
Geben Sie die Farbe des nicht verwendeten Bereichs an. Die Syntax dieser Option finden Sie unter "Farbe".
Abschnitt im ffmpeg-utils-Handbuch. Der Standardwert von Farbe ist schwarz".
Beispiele
· Produzieren Sie 8x8 PNG-Kacheln aller Keyframes (-skip_frame kein Schlüssel) in einem Film:
ffmpeg -skip_frame nokey -i file.avi -vf 'scale=128:72,tile=8x8' -an -vsync 0 keyframes%03d.png
Die -vsync 0 ist notwendig, um zu verhindern ffmpeg vom Duplizieren jedes Ausgabeframes auf
Anpassung an die ursprünglich erkannte Bildrate.
· Zeigen Sie 5 Bilder in einem Bereich von "3x2"-Rahmen an, mit 7 Pixeln dazwischen und 2
Pixel des Anfangsrands, mit gemischten flachen und benannten Optionen:
tile=3x2:nb_frames=5:padding=7:margin=2
Interlace
Führen Sie verschiedene Arten von zeitlichem Halbbild-Interlacing durch.
Frames werden beginnend mit 1 gezählt, sodass der erste Eingabeframe als ungerade gilt.
Der Filter akzeptiert die folgenden Optionen:
Modus
Legen Sie den Interlacing-Modus fest. Diese Option kann auch als Wert angegeben werden
allein. Unten finden Sie eine Liste mit Werten für diese Option.
Verfügbare Werte sind:
verschmelzen, 0
Verschiebe ungerade Frames in das obere Halbbild, gerade in das untere Halbbild und erzeuge a
Rahmen mit doppelter Höhe bei halber Bildrate.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
Ausgang:
11111 33333
22222 44444
11111 33333
22222 44444
11111 33333
22222 44444
11111 33333
22222 44444
drop_ungerade, 1
Nur gerade Frames ausgeben, ungerade Frames werden verworfen, wodurch ein Frame mit unverändertem . erzeugt wird
Höhe bei halber Framerate.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
Ausgang:
22222 44444
22222 44444
22222 44444
22222 44444
drop_even, 2
Nur ungerade Frames ausgeben, gerade Frames werden verworfen, wodurch ein Frame mit unverändertem . erzeugt wird
Höhe bei halber Framerate.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
Ausgang:
11111 33333
11111 33333
11111 33333
11111 33333
Pad, 3
Erweitern Sie jeden Frame auf die volle Höhe, aber füllen Sie abwechselnde Zeilen mit Schwarz auf, wodurch a . erzeugt wird
Frame mit doppelter Höhe bei gleicher Eingabe-Framerate.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
Ausgang:
11111 ..... 33333 .....
..... 22222 ..... 44444
11111 ..... 33333 .....
..... 22222 ..... 44444
11111 ..... 33333 .....
..... 22222 ..... 44444
11111 ..... 33333 .....
..... 22222 ..... 44444
interleave_top, 4
Verschachteln Sie das obere Halbbild von ungeraden Bildern mit dem unteren Halbbild von geraden Bildern,
Generieren eines Frames mit unveränderter Höhe bei halber Framerate.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111<- 22222 33333<- 44444
11111 22222<- 33333 44444<-
11111<- 22222 33333<- 44444
11111 22222<- 33333 44444<-
Ausgang:
11111 33333
22222 44444
11111 33333
22222 44444
interleave_bottom, 5
Verschachteln Sie das untere Halbbild von ungeraden Bildern mit dem oberen Halbbild von geraden Bildern,
Generieren eines Frames mit unveränderter Höhe bei halber Framerate.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111 22222<- 33333 44444<-
11111<- 22222 33333<- 44444
11111 22222<- 33333 44444<-
11111<- 22222 33333<- 44444
Ausgang:
22222 44444
11111 33333
22222 44444
11111 33333
interlacex2, 6
Doppelte Bildrate bei unveränderter Höhe. Es werden Rahmen eingefügt, die jeweils die
zweites zeitliches Feld aus dem vorherigen Eingabebild und das erste zeitliche Feld
ab dem nächsten Eingabeframe. Dieser Modus basiert auf dem top_field_first Flag. Sinnvoll
für Interlaced-Videoanzeigen ohne Halbbildsynchronisation.
------> Zeit
Eingang:
Rahmen 1 Rahmen 2 Rahmen 3 Rahmen 4
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
11111 22222 33333 44444
Ausgang:
11111 22222 22222 33333 33333 44444 44444
11111 11111 22222 22222 33333 33333 44444
11111 22222 22222 33333 33333 44444 44444
11111 11111 22222 22222 33333 33333 44444
Numerische Werte sind veraltet, werden jedoch aus Gründen der Abwärtskompatibilität akzeptiert.
Der Standardmodus ist "Zusammenführen".
Fahnen
Legen Sie Flags fest, die den Filterprozess beeinflussen.
Verfügbarer Wert für Fahnen ist:
Tiefpassfilter, vlfp
Aktivieren Sie die vertikale Tiefpassfilterung im Filter. Vertikale Tiefpassfilterung ist
erforderlich, wenn Sie ein Interlaced-Ziel aus einer progressiven Quelle erstellen, die
enthält hochfrequente vertikale Details. Filterung reduziert Interlace 'Twitter'
und Moiré-Musterung.
Die vertikale Tiefpassfilterung kann nur aktiviert werden für Modus interleave_top und
interleave_bottom.
transponieren
Transponieren Sie Zeilen mit Spalten im Eingabevideo und spiegeln Sie es optional.
Es akzeptiert die folgenden Parameter:
dir Geben Sie die Transpositionsrichtung an.
Kann folgende Werte annehmen:
0, 4, cclock_flip
Um 90 Grad gegen den Uhrzeigersinn drehen und vertikal spiegeln (Standard), das heißt:
LR Ll
. . -> . .
lr Rr
1, 5, Uhr
Um 90 Grad im Uhrzeigersinn drehen, das heißt:
LR lL
. . -> . .
lr rR
2, 6, Uhr
Um 90 Grad gegen den Uhrzeigersinn drehen, das heißt:
LR Rr
. . -> . .
lr Ll
3, 7, clock_flip
Um 90 Grad im Uhrzeigersinn drehen und vertikal spiegeln, das heißt:
LR rR
. . -> . .
lr lL
Bei Werten zwischen 4-7 wird die Transponierung nur durchgeführt, wenn die Eingangsvideogeometrie
Hochformat und nicht Querformat. Diese Werte sind veraltet, die Option "Passthrough"
sollte stattdessen verwendet werden.
Numerische Werte sind veraltet und sollten zugunsten symbolischer Konstanten fallengelassen werden.
Durchgang
Wenden Sie die Transposition nicht an, wenn die Eingabegeometrie mit der durch das angegebenen übereinstimmt
Spezifizierter Wert. Es akzeptiert die folgenden Werte:
keine
Wenden Sie immer die Transposition an.
Porträt
Porträtgeometrie beibehalten (wenn Höhe >= Breite).
Landschaft
Landschaftsgeometrie beibehalten (wenn Breite >= Höhe).
Der Standardwert ist "keiner".
Um beispielsweise um 90 Grad im Uhrzeigersinn zu drehen und das Hochformat-Layout beizubehalten:
transpose=dir=1:passthrough=portrait
Der obige Befehl kann auch wie folgt angegeben werden:
transponieren=1:Hochformat
trimmen
Trimmen Sie die Eingabe, sodass die Ausgabe einen fortlaufenden Unterteil der Eingabe enthält.
Es akzeptiert die folgenden Parameter:
Anfang
Geben Sie den Zeitpunkt des Beginns des beibehaltenen Abschnitts an, dh des Frames mit dem Zeitstempel
Anfang wird der erste Frame in der Ausgabe sein.
Ende Geben Sie die Zeit des ersten Frames an, der verworfen wird, dh der Frame sofort
vor dem mit dem Zeitstempel Ende wird der letzte Frame in der Ausgabe sein.
start_pts
Dies ist das gleiche wie Anfang, außer dass diese Option den Startzeitstempel in der Zeitbasis setzt
Einheiten statt Sekunden.
end_pts
Dies ist das gleiche wie Ende, außer dass diese Option den Endzeitstempel in Zeitbasiseinheiten setzt
statt Sekunden.
Dauer
Die maximale Dauer der Ausgabe in Sekunden.
start_frame
Die Nummer des ersten Frames, der an die Ausgabe übergeben werden soll.
end_frame
Die Nummer des ersten Frames, der gelöscht werden soll.
Anfang, Ende und Dauer werden als Zeitdauerspezifikationen ausgedrückt; sehen Uhrzeit
Dauer Abschnitt in ffmpeg-utils(1) manuell für die akzeptierte Syntax.
Beachten Sie, dass die ersten beiden Sätze der Start-/Endoptionen und die Dauer Option schau dir die an
Frame-Zeitstempel, während die _frame-Varianten einfach die Frames zählen, die durch die
Filter. Beachten Sie auch, dass dieser Filter die Zeitstempel nicht ändert. Wenn Sie es wünschen
Ausgabezeitstempel bei Null beginnen, fügen Sie einen Setpts-Filter nach dem Trim-Filter ein.
Wenn mehrere Start- oder Endoptionen festgelegt sind, versucht dieser Filter gierig zu sein und alle
Frames, die mindestens einer der angegebenen Einschränkungen entsprechen. Um nur den Teil zu behalten, der
entspricht allen Beschränkungen auf einmal, verketten Sie mehrere Trim-Filter.
Die Standardeinstellungen sind so, dass alle Eingaben beibehalten werden. So ist es zB möglich, nur die
Endwerte, um alles vor der angegebenen Zeit zu behalten.
Beispiele:
· Alles außer der zweiten Minute der Eingabe löschen:
ffmpeg -i EINGANG -vf trim=60:120
· Behalten Sie nur die erste Sekunde:
ffmpeg -i INPUT -vf trim=Dauer=1
unscharf
Schärfen oder verwischen Sie das Eingangsvideo.
Es akzeptiert die folgenden Parameter:
luma_msize_x, lx
Legen Sie die horizontale Größe der Luma-Matrix fest. Es muss eine ungerade ganze Zahl zwischen 3 und 63 sein
Standardwert ist 5.
luma_msize_y, ly
Stellen Sie die vertikale Größe der Luma-Matrix ein. Es muss eine ungerade ganze Zahl zwischen 3 und 63 sein
Standardwert ist 5.
Luma_Betrag, la
Stellen Sie die Stärke des Luma-Effekts ein. Es muss eine Gleitkommazahl sein, vernünftige Werte
zwischen -1.5 und 1.5 liegen.
Negative Werte machen das Eingangsvideo unscharf, während positive Werte es schärfer machen, a
Der Wert Null deaktiviert den Effekt.
Der Standardwert ist 1.0.
chroma_msize_x, cx
Stellen Sie die horizontale Größe der Chroma-Matrix ein. Es muss eine ungerade ganze Zahl zwischen 3 und 63 sein
Standardwert ist 5.
chroma_msize_y, cy
Stellen Sie die vertikale Größe der Chroma-Matrix ein. Es muss eine ungerade ganze Zahl zwischen 3 und 63 sein
Standardwert ist 5.
Chroma_Betrag, ca
Stellen Sie die Stärke des Chroma-Effekts ein. Es muss eine Gleitkommazahl sein, vernünftige Werte
zwischen -1.5 und 1.5 liegen.
Negative Werte machen das Eingangsvideo unscharf, während positive Werte es schärfer machen, a
Der Wert Null deaktiviert den Effekt.
Der Standardwert ist 0.0.
OpenCL
Wenn auf 1 gesetzt, geben Sie die Verwendung von OpenCL-Fähigkeiten an, nur verfügbar, wenn FFmpeg war
mit "--enable-opencl" konfiguriert. Der Standardwert ist 0.
Alle Parameter sind optional und entsprechen standardmäßig der Zeichenfolge '5:5:1.0:5:5:0.0'.
Beispiele
· Wenden Sie einen starken Luma-Scharf-Effekt an:
unsharp=luma_msize_x=7:luma_msize_y=7:luma_amount=2.5
· Wenden Sie eine starke Unschärfe der Luma- und Chroma-Parameter an:
unsharp=7:7:-2:7:7:-2
uspp
Wenden Sie einen ultralangsamen/einfachen Nachbearbeitungsfilter an, der das Bild komprimiert und dekomprimiert
bei mehreren (oder - im Falle von qualitativ hochwertiges Stufe 8 - alle) verschiebt und durchschnittlich die Ergebnisse.
Der Unterschied zum Verhalten von spp besteht darin, dass uspp tatsächlich jedes codiert und decodiert
Fall mit libavcodec Snow, während spp ein vereinfachtes Intra nur 8x8 DCT ähnlich wie . verwendet
MJPEG.
Der Filter akzeptiert die folgenden Optionen:
qualitativ hochwertiges
Qualität einstellen. Diese Option definiert die Anzahl der Ebenen für die Mittelwertbildung. Es akzeptiert ein
Ganzzahl im Bereich 0-8. Bei 0 hat der Filter keine Wirkung. Ein Wert von 8
bedeutet die höhere Qualität. Für jede Erhöhung dieses Wertes sinkt die Geschwindigkeit um einen Faktor
von ungefähr 2. Der Standardwert ist 3.
qp Erzwinge einen konstanten Quantisierungsparameter. Wenn nicht gesetzt, verwendet der Filter die QP von
den Videostream (sofern verfügbar).
Vectorscope
Zeigen Sie 2 Farbkomponentenwerte in der zweidimensionalen Grafik an (die als a . bezeichnet wird).
Vektorskop).
Dieser Filter akzeptiert die folgenden Optionen:
Modus m
Stellen Sie den Vektorskopmodus ein.
Es akzeptiert die folgenden Werte:
grau
Grauwerte werden im Diagramm angezeigt, höhere Helligkeit bedeutet, dass mehr Pixel gleich sind
Farbwert der Komponente vor Ort im Diagramm. Dies ist der Standardmodus.
Farbe
Grauwerte werden im Diagramm angezeigt. Umgebende Pixelwerte, die nicht
im Videobild vorhanden sind, werden in einem Farbverlauf von 2 Farbkomponenten gezeichnet, die eingestellt sind
nach Option "x" und "y".
color2
Tatsächliche Farbkomponentenwerte, die im Videobild vorhanden sind, werden im Diagramm angezeigt.
color3
Ähnlich wie color2, aber höhere Häufigkeit der gleichen Werte "x" und "y" im Diagramm
erhöht den Wert einer anderen Farbkomponente, bei der es sich um die Luminanz durch Standardwerte handelt
von "x" und "y".
color4
Tatsächliche Farben, die im Videoframe vorhanden sind, werden im Diagramm angezeigt. Wenn zwei verschiedene
Farben werden auf dieselbe Position im Diagramm abgebildet, dann Farbe mit höherem Wert der Komponente nicht
im Diagramm vorhanden ist ausgewählt.
x Legen Sie fest, welche Farbkomponente auf der X-Achse dargestellt wird. Standard ist 1.
y Legen Sie fest, welche Farbkomponente auf der Y-Achse dargestellt wird. Standard ist 2.
Intensität, i
Stellen Sie die Intensität ein, die von den Modi verwendet wird: Grau, Farbe und Farbe3 zum Erhöhen der Helligkeit von
Farbkomponente, die die Häufigkeit der (X, Y)-Position im Diagramm darstellt.
Umschlag, e
keine
Kein Umschlag, dies ist die Standardeinstellung.
sofortig
Sofortige Hüllkurve, selbst dunkelste Einzelpixel werden deutlich hervorgehoben.
Haupt
Halten Sie die maximalen und minimalen Werte, die im Diagramm über die Zeit angezeigt werden. So kannst du
immer noch Werte außerhalb des Bereichs erkennen, ohne ständig auf das Vektorskop zu schauen.
Spitze+Sofort
Peak- und Instant-Hüllkurve zusammen kombiniert.
vidstabdetektieren
Analysieren Sie die Videostabilisierung/Deshaking. Führen Sie Durchgang 1 von 2 durch, siehe vidstabtransformieren für pass
2.
Dieser Filter generiert eine Datei mit relativen Translations- und Rotationstransformationsinformationen
über nachfolgende Frames, die dann von den vidstabtransformieren Filter.
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie FFmpeg mit konfigurieren
"--enable-libvidstab".
Dieser Filter akzeptiert die folgenden Optionen:
Folge
Legen Sie den Pfad zu der Datei fest, die zum Schreiben der Transformationsinformationen verwendet wird. Standardwert ist
transformiert.trf.
Zittern
Stellen Sie ein, wie verwackelt das Video ist und wie schnell die Kamera ist. Es akzeptiert eine ganze Zahl in der
Bereich 1-10, ein Wert von 1 bedeutet geringes Zittern, ein Wert von 10 bedeutet starkes Zittern.
Der Standardwert ist 5.
Genauigkeit
Stellen Sie die Genauigkeit des Erkennungsprozesses ein. Es muss ein Wert im Bereich von 1-15 sein. EIN
Ein Wert von 1 bedeutet eine geringe Genauigkeit, ein Wert von 15 bedeutet eine hohe Genauigkeit. Der Standardwert ist 15.
Schrittlänge
Stellen Sie die Schrittweite des Suchprozesses ein. Der Bereich um das Minimum wird mit 1 Pixel gescannt
Auflösung. Der Standardwert ist 6.
Minkontrast
Stellen Sie den minimalen Kontrast ein. Unterhalb dieses Wertes wird ein lokales Messfeld verworfen. Muss sein
ein Gleitkommawert im Bereich 0-1. Der Standardwert ist 0.3.
Stativ
Stellen Sie die Referenzbildnummer für den Stativmodus ein.
Wenn aktiviert, wird die Bewegung der Frames mit einem Referenzframe im gefilterten . verglichen
Stream, identifiziert durch die angegebene Nummer. Die Idee ist, alle Bewegungen in auszugleichen
eine mehr oder weniger statische Szene und halten Sie die Kameraansicht absolut ruhig.
Wenn es auf 0 gesetzt ist, ist es deaktiviert. Die Frames werden ab 1 gezählt.
erklären
Felder und Transformationen in den resultierenden Frames anzeigen. Es akzeptiert eine ganze Zahl im Bereich
0-2. Der Standardwert ist 0, wodurch jede Visualisierung deaktiviert wird.
Beispiele
· Standardwerte verwenden:
vidstabdetektieren
· Analysieren Sie stark verwackelte Filme und legen Sie die Ergebnisse in eine Datei meinetransforms.trf:
vidstabdetect=wakiness=10:accuracy=15:result="mytransforms.trf"
· Visualisieren Sie das Ergebnis interner Transformationen im resultierenden Video:
vidstabdetect=show=1
· Analysieren Sie ein Video mit mittlerer Verwacklung mit ffmpeg:
ffmpeg -i input -vf vidstabdetect=shakiness=5:show=1 dummy.avi
vidstabtransformieren
Videostabilisierung/Deshaking: Pass 2 von 2, siehe vidstabdetektieren für Durchgang 1.
Lesen Sie eine Datei mit Transformationsinformationen für jeden Frame und wenden/kompensieren Sie diese. Zusammen
an. Nach der Installation können Sie HEIC-Dateien mit der vidstabdetektieren filter dies kann verwendet werden, um Videos zu entschütteln. Siehe auch
<http://public.hronopik.de/vid.stab>. Es ist wichtig, auch die unscharf filtern, siehe
unten mit.
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie FFmpeg mit konfigurieren
"--enable-libvidstab".
Optionen
Varianten des Eingangssignals:
Legen Sie den Pfad zu der Datei fest, die zum Lesen der Transformationen verwendet wird. Standardwert ist transformiert.trf.
Glättung
Legen Sie die Anzahl der Bilder fest (Wert*2 + 1), die für die Tiefpassfilterung der Kamera verwendet werden
Bewegungen. Der Standardwert ist 10.
Zum Beispiel bedeutet eine Zahl von 10, dass 21 Frames verwendet werden (10 in der Vergangenheit und 10 in der
Zukunft), um die Bewegung im Video zu glätten. Ein größerer Wert führt zu einem flüssigeren Video,
begrenzt aber die Beschleunigung der Kamera (Schwenk-/Neigebewegungen). 0 ist ein Sonderfall
wo eine statische Kamera simuliert wird.
optalgo
Legen Sie den Algorithmus zur Optimierung des Kamerapfads fest.
Akzeptierte Werte sind:
gauss
Gaußscher Kernel-Tiefpassfilter bei Kamerabewegung (Standard)
avg Mittelwertbildung bei Transformationen
maxshift
Legen Sie die maximale Anzahl von Pixeln fest, um Frames zu übersetzen. Der Standardwert ist -1, d. h. nein
Grenze.
Maximalwinkel
Legen Sie den maximalen Winkel im Bogenmaß (Grad*PI/180) fest, um Frames zu drehen. Der Standardwert ist -1,
bedeutet keine Grenze.
Ernte
Legen Sie fest, wie mit Rändern umgegangen wird, die aufgrund der Bewegungskompensation möglicherweise sichtbar sind.
Verfügbare Werte sind:
halten
Bildinformationen aus dem vorherigen Frame beibehalten (Standard)
Schwarz
Fülle den Rand schwarz
umkehren
Transformationen invertieren, wenn auf 1 gesetzt. Der Standardwert ist 0.
relativ
Betrachten Sie Transformationen als relativ zum vorherigen Frame, wenn auf 1 gesetzt, absolut, wenn auf 0 gesetzt.
Der Standardwert ist 0.
Zoom
Stellen Sie den Prozentsatz zum Zoomen ein. Ein positiver Wert führt zu einem Zoom-In-Effekt, ein negativer
Wert in einem Zoom-Out-Effekt. Der Standardwert ist 0 (kein Zoom).
optzoom
Stellen Sie den optimalen Zoom ein, um Ränder zu vermeiden.
Akzeptierte Werte sind:
0 behindert
1 optimaler statischer Zoomwert wird ermittelt (nur sehr starke Bewegungen führen zu
sichtbare Ränder) (Standard)
2 optimaler adaptiver Zoomwert wird bestimmt (keine Ränder sind sichtbar), siehe
Zoomgeschwindigkeit
Beachten Sie, dass der beim Zoom angegebene Wert zu dem hier berechneten addiert wird.
Zoomgeschwindigkeit
Stellen Sie den Prozentsatz ein, um jeden Frame maximal zu vergrößern (aktiviert, wenn optzoom ist auf 2) eingestellt. Reichweite ist
von 0 bis 5 ist der Standardwert 0.25.
interpol
Geben Sie die Art der Interpolation an.
Verfügbare Werte sind:
nicht keine Interpolation
linear
linear nur horizontal
bilinear
linear in beide Richtungen (Standard)
bikubisch
kubisch in beide Richtungen (langsam)
Stativ
Aktivieren Sie den virtuellen Stativmodus, wenn er auf 1 eingestellt ist, was äquivalent zu . ist
"relativ=0:glätten=0". Der Standardwert ist 0.
Verwenden Sie auch die Option "Stativ" von vidstabdetektieren.
debuggen
Erhöhen Sie die Protokollausführlichkeit, wenn sie auf 1 gesetzt ist. Auch die erkannten globalen Bewegungen werden in geschrieben
die temporäre Datei global_motions.trf. Der Standardwert ist 0.
Beispiele
· Verwenden ffmpeg für eine typische Stabilisierung mit Standardwerten:
ffmpeg -i inp.mpeg -vf vidstabtransform,unsharp=5:5:0.8:3:3:0.4 inp_stabilized.mpeg
Beachten Sie die Verwendung der unscharf Filter, der immer empfohlen wird.
· Vergrößern Sie etwas mehr und laden Sie Transformationsdaten aus einer bestimmten Datei:
vidstabtransform=zoom=5:input="mytransforms.trf"
· Glätten Sie das Video noch mehr:
vidstabtransform=Glättung=30
vflipp
Spiegeln Sie das Eingangsvideo vertikal.
Um beispielsweise ein Video vertikal zu spiegeln mit ffmpeg:
ffmpeg -i in.avi -vf "vflip" out.avi
Vignette
Machen Sie einen natürlichen Vignettierungseffekt oder kehren Sie ihn um.
Der Filter akzeptiert die folgenden Optionen:
Winkel, a
Stellen Sie den Linsenwinkelausdruck als eine Anzahl von Radianten ein.
Der Wert wird im Bereich "[0,PI/2]" abgeschnitten.
Standardwert: "PI/5"
x0
y0 Legen Sie die Ausdrücke für die Mittelpunktkoordinaten fest. Jeweils "w/2" und "h/2" standardmäßig.
Modus
Vorwärts-/Rückwärtsmodus einstellen.
Verfügbare Modi sind:
Je größer der Abstand vom Mittelpunkt, desto dunkler wird das Bild.
rückwärts
Je größer der Abstand vom Mittelpunkt, desto heller wird das Bild.
Dies kann verwendet werden, um einen Vignetteneffekt umzukehren, obwohl es keine Automatik gibt
Erkennung zum Extrahieren der Linse Winkel und andere Einstellungen (noch). Es kann auch verwendet werden
um einen brennenden Effekt zu erzeugen.
Standardwert ist .
eval
Auswertungsmodus für die Ausdrücke einstellen (Winkel, x0, y0).
Es akzeptiert die folgenden Werte:
init
Werte Ausdrücke nur einmal während der Filterinitialisierung aus.
Rahmen
Bewerten Sie Ausdrücke für jeden eingehenden Frame. Das ist viel langsamer als die init
Modus, da alle Skalierer neu berechnet werden müssen, aber erweiterte
dynamische Ausdrücke.
Standardwert ist init.
Dithering
Stellen Sie Dithering ein, um die kreisförmigen Streifeneffekte zu reduzieren. Der Standardwert ist 1 (aktiviert).
Aussehen
Vignettenaspekt einstellen. Mit dieser Einstellung kann man die Form der Vignette anpassen.
Wenn Sie diesen Wert auf den SAR-Wert der Eingabe einstellen, wird eine rechteckige Vignettierung erstellt
nach den Abmessungen des Videos.
Standard ist "1/1".
Ausdrücke
Die Alpha, x0 und y0 Ausdrücke können die folgenden Parameter enthalten.
w
h Eingabebreite und -höhe
n die Anzahl der Eingaberahmen, beginnend bei 0
pts die PTS-Zeit (Presentation TimeStamp) des gefilterten Videoframes, ausgedrückt in TB
Einheiten, NAN wenn nicht definiert
r Bildrate des Eingangsvideos, NAN, wenn die Eingangsbildrate unbekannt ist
t der PTS (Presentation TimeStamp) des gefilterten Videoframes, ausgedrückt in Sekunden,
NAN wenn nicht definiert
tb Zeitbasis des Eingangsvideos
Beispiele
· Wenden Sie einen einfachen starken Vignettierungseffekt an:
Vignette=PI/4
· Erstellen Sie eine flackernde Vignettierung:
vignette='PI/4+zufällig(1)*PI/50':eval=frame
vstack
Stapeln Sie Eingabevideos vertikal.
Alle Streams müssen dasselbe Pixelformat und dieselbe Breite aufweisen.
Beachten Sie, dass dieser Filter schneller ist als die Verwendung von Auflage und Unterlage filtern, um dieselbe Ausgabe zu erstellen.
Der Filter akzeptiert die folgende Option:
nb_eingaben
Legen Sie die Anzahl der Eingabestreams fest. Standard ist 2.
w3fdif
Deinterlace das Eingangsvideo ("w3fdif" steht für "Weston 3 Field Deinterlacing Filter").
Basierend auf dem von Martin Weston für BBC R&D beschriebenen Prozess und implementiert auf Basis der
De-Interlace-Algorithmus, geschrieben von Jim Easterbrook für BBC R&D, das Weston 3-Feld
Der Deinterlacing-Filter verwendet von BBC R&D berechnete Filterkoeffizienten.
Es gibt zwei Sätze von Filterkoeffizienten, die sogenannten "einfach": und "komplex". Welcher Satz von
Filterkoeffizienten verwendet wird, kann durch Übergabe eines optionalen Parameters eingestellt werden:
Filter
Stellen Sie die Interlacing-Filterkoeffizienten ein. Akzeptiert einen der folgenden Werte:
einfach
Einfacher Filterkoeffizientensatz.
Komplex
Komplexerer Filterkoeffizientensatz.
Standardwert ist Komplex.
deint
Geben Sie an, welche Frames deinterlaced werden sollen. Akzeptieren Sie einen der folgenden Werte:
alle Alle Frames deinterlacen,
verschachtelt
Deinterlacen Sie nur Frames, die als interlaced markiert sind.
Standardwert ist alle.
Wellenform
Videowellenform-Monitor.
Der Wellenformmonitor zeichnet die Intensität der Farbkomponenten auf. Standardmäßig nur Luminanz. Jeder
Spalte der Wellenform entspricht einer Spalte von Pixeln im Quellvideo.
Es akzeptiert die folgenden Optionen:
Modus m
Kann entweder "Zeile" oder "Spalte" sein. Standard ist "Spalte". Im Zeilenmodus wird die Grafik auf dem
linke Seite repräsentiert den Farbkomponentenwert 0 und die rechte Seite repräsentiert den Wert =
255. Im Spaltenmodus repräsentiert die obere Seite den Farbkomponentenwert = 0 und die untere Seite
stellt Wert = 255 dar.
Intensität, i
Intensität einstellen. Kleinere Werte sind nützlich, um herauszufinden, wie viele Werte gleich sind
Luminanz werden über die Eingabezeilen/-spalten verteilt. Der Standardwert ist 0.04. Dürfen
Bereich ist [0, 1].
Spiegel, r
Spiegelungsmodus einstellen. 0 bedeutet ungespiegelt, 1 bedeutet gespiegelt. Im gespiegelten Modus höher
Werte werden auf der linken Seite für den Modus "Zeile" und oben für "Spalte" dargestellt
Modus. Standard ist 1 (gespiegelt).
Anzeige, d
Anzeigemodus einstellen. Es akzeptiert die folgenden Werte:
Auflage
Präsentiert Informationen, die mit denen in der "Parade" identisch sind, außer dass die Grafiken
darstellende Farbkomponenten werden direkt überlagert.
Dieser Anzeigemodus erleichtert das Erkennen relativer Unterschiede oder Ähnlichkeiten in
überlappende Bereiche der Farbkomponenten, die identisch sein sollen, wie z
als neutrales Weiß, Grau oder Schwarz.
Parade
Separate Grafik für die Farbkomponenten nebeneinander im "Reihen"-Modus oder einzeln anzeigen
untereinander im "Spalten"-Modus.
Mit diesem Anzeigemodus können Sie leicht Farbstiche in den Lichtern erkennen und
Schatten eines Bildes durch Vergleich der Konturen der oberen und unteren Grafik von
jede Wellenform. Da Weiß, Grau und Schwarz durch genau gleich gekennzeichnet sind
Mengen an Rot, Grün und Blau, neutrale Bereiche des Bildes sollten drei
Wellenformen von ungefähr gleicher Breite/Höhe. Wenn nicht, ist die Korrektur einfach durchzuführen
indem Sie Pegelanpassungen der drei Wellenformen vornehmen.
Standard ist "Parade".
Komponenten c
Legen Sie fest, welche Farbkomponenten angezeigt werden sollen. Standard ist 1, was nur Luminanz oder Rot bedeutet
Farbkomponente, wenn die Eingabe im RGB-Farbraum erfolgt. Wenn zum Beispiel auf 7 eingestellt ist, wird es
alle 3 (wenn) verfügbaren Farbkomponenten anzeigen.
Umschlag, e
keine
Kein Umschlag, dies ist die Standardeinstellung.
sofortig
Sofortige Hüllkurve, Minimal- und Maximalwerte, die in der Grafik dargestellt werden, werden leicht angezeigt
sichtbar auch bei kleinem "step"-Wert.
Haupt
Halten Sie die minimalen und maximalen Werte, die im Diagramm über die Zeit angezeigt werden. So kannst du
immer noch Werte außerhalb des Bereichs erkennen, ohne ständig auf Wellenformen zu schauen.
Spitze+Sofort
Peak- und Instant-Hüllkurve zusammen kombiniert.
Filter, f
Tiefpass
Keine Filterung, dies ist die Standardeinstellung.
Wohnung
Luma und Chroma kombiniert.
eine Wohnung
Ähnlich wie oben, zeigt jedoch einen Unterschied zwischen blauem und rotem Chroma.
Chroma
Zeigt nur Chroma an.
achromatisch
Ähnlich wie oben, zeigt jedoch einen Unterschied zwischen blauem und rotem Chroma.
Farbe
Zeigt den tatsächlichen Farbwert auf der Wellenform an.
XBR
Wenden Sie den hochwertigen xBR-Vergrößerungsfilter an, der für Pixelkunst entwickelt wurde. Es
folgt einer Reihe von Kantenerkennungsregeln, siehe
<http://www.libretro.com/forums/viewtopic.php?f=6&t=134>.
Es akzeptiert die folgende Option:
n Stellen Sie das Skalierungsmaß ein: 2 für "2xBR", 3 für "3xBR" und 4 für "4xBR". Standard ist 3.
jadif
Deinterlace das Eingangsvideo ("yadif" bedeutet "noch ein Deinterlacing-Filter").
Es akzeptiert die folgenden Parameter:
Modus
Der zu übernehmende Interlacing-Modus. Es akzeptiert einen der folgenden Werte:
0, send_frame
Ausgabe eines Frames für jeden Frame.
1, send_field
Geben Sie für jedes Feld einen Frame aus.
2, send_frame_nospatial
Wie "send_frame", aber es überspringt die Spatial Interlacing-Prüfung.
3, send_field_nospatial
Wie "send_field", aber es überspringt die Prüfung des räumlichen Zeilensprungs.
Der Standardwert ist "send_frame".
Parität
Die für das eingegebene Zeilensprungvideo angenommene Bildfeldparität. Es akzeptiert eine der
folgende Werte:
0, tff
Angenommen, das oberste Feld ist das erste.
1, bff
Angenommen, das untere Feld ist das erste.
-1, Auto
Aktivieren Sie die automatische Erkennung der Feldparität.
Der Standardwert ist "auto". Wenn das Interlacing unbekannt ist oder der Decoder nicht
Exportieren Sie diese Informationen, das oberste Feld wird zuerst angenommen.
deint
Geben Sie an, welche Frames deinterlaced werden sollen. Akzeptieren Sie einen der folgenden Werte:
0, alle
Deinterlacen Sie alle Frames.
1, verschachtelt
Deinterlacen Sie nur Frames, die als interlaced markiert sind.
Der Standardwert ist "alle".
Zoompan
Wenden Sie den Zoom & Pan-Effekt an.
Dieser Filter akzeptiert die folgenden Optionen:
Zoomen, z
Stellen Sie den Zoom-Ausdruck ein. Standard ist 1.
x
y Legen Sie den x- und y-Ausdruck fest. Standard ist 0.
d Legen Sie den Dauerausdruck in der Anzahl der Frames fest. Dies legt fest, wie viele
Frames-Effekt hält für ein einzelnes Eingabebild an.
s Legen Sie die Ausgabebildgröße fest, der Standardwert ist 'hd720'.
Jeder Ausdruck kann die folgenden Konstanten enthalten:
in_w, iw
Eingabebreite.
in_h, ih
Eingabehöhe.
aus_w, ow
Ausgabebreite.
aus_h, oh
Ausgabehöhe.
in Eingabebildanzahl.
on Anzahl der Ausgabe-Frames.
x
y Zuletzt berechnete 'x'- und 'y'-Position aus 'x'- und 'y'-Ausdruck für die aktuelle Eingabe
Rahmen.
px
py 'x' und 'y' des letzten Ausgabeframes des vorherigen Eingabeframes oder 0, wenn es noch nicht vorhanden war
solchen Rahmen (erster Eingaberahmen).
Zoom
Zuletzt berechneter Zoom aus 'z'-Ausdruck für das aktuelle Eingabebild.
pzoom
Zuletzt berechneter Zoom des letzten Ausgabeframes des vorherigen Eingabeframes.
Dauer
Anzahl der Ausgabeframes für das aktuelle Eingabeframe. Berechnet aus 'd'-Ausdruck für
jedes Eingabeframe.
Dauer
Anzahl der Ausgabeframes, die für das vorherige Eingabeframe erstellt wurden
a Rationale Zahl: Eingabebreite / Eingabehöhe
sar Beispiel-Seitenverhältnis
geben Anzeige-Seitenverhältnis
Beispiele
· Vergrößern Sie bis zu 1.5 und schwenken Sie gleichzeitig zu einer Stelle in der Nähe der Bildmitte:
zoompan=z='min(zoom+0.0015,1.5)':d=700:x='if(gte(zoom,1.5),x,x+1/a)':y='if(gte(zoom,1.5),y,y+1)':s=640x360
· Vergrößern Sie bis zu 1.5 und schwenken Sie immer in die Bildmitte:
zoompan=z='min(zoom+0.0015,1.5)':d=700:x='iw/2-(iw/zoom/2)':y='ih/2-(ih/zoom/2)'
VIDEO QUELLEN
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Videoquellen.
puffern
Puffern Sie Videoframes und stellen Sie sie der Filterkette zur Verfügung.
Diese Quelle ist hauptsächlich für eine programmatische Verwendung gedacht, insbesondere durch die Schnittstelle
definiert in libavfilter/vsrc_buffer.h.
Es akzeptiert die folgenden Parameter:
Video Größe
Geben Sie die Größe (Breite und Höhe) der gepufferten Videobilder an. Für die Syntax von
Aktivieren Sie diese Option "Video Größe" Abschnitt in ffmpeg-utils manuell.
Breite
Die Breite des Eingangsvideos.
Höhe
Die Höhe des Eingangsvideos.
pix_fmt
Eine Zeichenfolge, die das Pixelformat der gepufferten Videoframes darstellt. Es kann sein
Nummer, die einem Pixelformat entspricht, oder ein Pixelformatname.
Zeitbasis
Geben Sie die Zeitbasis an, die von den Zeitstempeln der gepufferten Frames angenommen wird.
Bildrate
Geben Sie die für den Videostream erwartete Bildrate an.
pixel_aspekt, sar
Das Beispielseitenverhältnis (Pixel) des Eingangsvideos.
sws_param
Geben Sie die optionalen Parameter an, die für den automatisch aktivierten Skalierungsfilter verwendet werden sollen
eingefügt, wenn eine Eingabeänderung in der Eingabegröße oder im Eingabeformat erkannt wird.
Beispielsweise:
buffer=width=320:height=240:pix_fmt=yuv410p:time_base=1/24:sar=1
weist die Quelle an, Videoframes mit der Größe 320x240 und mit dem Format zu akzeptieren
"yuv410p", wobei 1/24 als Zeitbasis und quadratische Pixel des Zeitstempels angenommen wird (1:1 Beispielseitenverhältnis)
Verhältnis). Da das Pixelformat mit dem Namen "yuv410p" der Zahl 6 entspricht (überprüfe die
enum AVPixelFormat-Definition in libavutil/pixfmt.h), entspricht dieses Beispiel:
buffer=size=320x240:pixfmt=6:time_base=1/24:pixel_aspect=1/1
Alternativ können die Optionen als flacher String angegeben werden, aber diese Syntax ist
veraltet:
Breite:Höhe:pix_fmt:time_base.num:time_base.den:pixel_aspekt.num:pixel_aspect.den[:sws_param]
cellauto
Erstellen Sie ein Muster, das von einem elementaren zellulären Automaten generiert wird.
Der Anfangszustand des zellularen Automaten kann definiert werden durch die Dateinamen und
Anleitungen Optionen. Wenn solche Optionen nicht angegeben werden, wird zufällig ein Anfangszustand erzeugt.
Bei jedem neuen Frame wird eine neue Zeile im Video mit dem Ergebnis des Mobilfunks gefüllt
Automat der nächsten Generation. Das Verhalten beim Füllen des gesamten Rahmens wird durch die
blättern .
Diese Quelle akzeptiert die folgenden Optionen:
Dateiname, f
Lesen Sie den anfänglichen Zustand des zellularen Automaten, dh die Startzeile, aus dem angegebenen
Datei. In der Datei wird jedes Nicht-Leerzeichen als lebendige Zelle betrachtet, a
newline beendet die Zeile und weitere Zeichen in der Datei werden ignoriert.
Muster, p
Lesen Sie den anfänglichen Zustand des zellularen Automaten, dh die Startzeile, aus dem angegebenen
String.
Jedes Zeichen in der Zeichenfolge, das kein Leerzeichen ist, wird als lebendige Zelle, als Zeilenumbruch, betrachtet
beendet die Zeile und weitere Zeichen in der Zeichenfolge werden ignoriert.
Bewertung, r
Stellen Sie die Videorate ein, d. h. die Anzahl der Bilder, die pro Sekunde erzeugt werden. Standard ist 25.
random_fill_ratio, Verhältnis
Legen Sie das zufällige Füllverhältnis für die erste Zeile des Mobilfunkautomaten fest. Es ist ein schwebendes
Punktzahlwert im Bereich von 0 bis 1, standardmäßig 1/PHI.
Diese Option wird ignoriert, wenn eine Datei oder ein Muster angegeben wird.
random_seed, Samen
Setzt den Seed zum zufälligen Füllen der Anfangszeile, muss eine ganze Zahl zwischen sein
0 und UINT32_MAX. Wenn nicht angegeben oder explizit auf -1 gesetzt, versucht der Filter,
Verwenden Sie einen guten Zufalls-Seed auf Best-Effort-Basis.
regieren
Legen Sie die Regel für den Mobilfunkautomaten fest, es handelt sich um eine Zahl im Bereich von 0 bis 255. Standardwert
ist 110.
Größe, s
Legen Sie die Größe des Ausgabevideos fest. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell.
If Dateinamen or Anleitungen angegeben ist, ist die Größe standardmäßig auf die Breite des
angegebene Anfangszustandszeile, und die Höhe wird auf gesetzt Breite * PHI.
If Größe gesetzt ist, muss es die Breite der angegebenen Musterzeichenfolge enthalten, und die
Das angegebene Muster wird in der größeren Reihe zentriert.
Wenn kein Dateiname oder keine Musterzeichenfolge angegeben wird, ist der Größenwert standardmäßig
"320x518" (wird für einen zufällig generierten Anfangszustand verwendet).
blättern
Wenn auf 1 gesetzt, scrollen Sie die Ausgabe nach oben, wenn alle Zeilen in der Ausgabe
schon gefüllt. Bei 0 wird die neu generierte Zeile über die oberste Zeile geschrieben
kurz nachdem die untere Reihe gefüllt ist. Standardmäßig auf 1.
start_voll, voller
Wenn der Wert auf 1 gesetzt ist, füllen Sie die Ausgabe vollständig mit generierten Zeilen, bevor Sie die
erster Rahmen. Dies ist das Standardverhalten, zum Deaktivieren setzen Sie den Wert auf 0.
Stich
Wenn auf 1 eingestellt, nähen Sie die linke und rechte Reihenkante zusammen. Dies ist die Standardeinstellung
Verhalten, zum Deaktivieren setzen Sie den Wert auf 0.
Beispiele
· Lesen Sie den Ausgangszustand aus Anleitungen, und geben Sie eine Ausgabe der Größe 200x400 an.
cellauto=f=Muster:s=200x400
· Generieren Sie eine zufällige Anfangszeile mit einer Breite von 200 Zellen mit einem Füllverhältnis von 2/3:
cellauto=verhältnis=2/3:s=200x200
· Erstellen Sie ein von Regel 18 generiertes Muster, beginnend mit einer einzelnen lebenden Zelle, die auf einem zentriert ist
Anfangsreihe mit Breite 100:
cellauto=p=@s=100x400:full=0:rule=18
· Geben Sie ein ausgefeilteres Anfangsmuster an:
cellauto=p='@@ @ @@':s=100x400:full=0:rule=18
Mandelbrot
Generieren Sie ein Mandelbrot-Mengen-Fraktal und zoomen Sie schrittweise zu dem mit angegebenen Punkt
start_x und start_y.
Diese Quelle akzeptiert die folgenden Optionen:
end_pts
Stellen Sie den Pkt-Wert des Terminals ein. Der Standardwert ist 400.
end_scale
Stellen Sie den Endskalenwert ein. Muss ein Gleitkommawert sein. Der Standardwert ist 0.3.
innere
Legen Sie den inneren Farbmodus fest, d. h. den Algorithmus, der zum Zeichnen des Mandelbrot-Fraktales verwendet wird
innerer Bereich.
Er nimmt einen der folgenden Werte an:
Schwarz
Schwarzmodus einstellen.
Konvergenz
Zeit bis zur Konvergenz anzeigen.
mincol
Legen Sie die Farbe basierend auf dem Punkt fest, der dem Ursprung der Iterationen am nächsten liegt.
Zeit
Periodenmodus einstellen.
Standardwert ist mincol.
Rettungs
Legen Sie den Bailout-Wert fest. Der Standardwert ist 10.0.
maxiter
Legen Sie das Maximum der vom Rendering-Algorithmus durchgeführten Iterationen fest. Standardwert ist
7189
äußere
Stellen Sie den äußeren Farbmodus ein. Er nimmt einen der folgenden Werte an:
iteration_count
Stellen Sie den Iterationszählmodus ein.
normalized_iteration_count
setze den normalisierten Iterationszählmodus.
Standardwert ist normalized_iteration_count.
Bewertung, r
Bildrate einstellen, ausgedrückt als Anzahl der Bilder pro Sekunde. Der Standardwert ist "25".
Größe, s
Rahmengröße einstellen. Die Syntax dieser Option finden Sie im Abschnitt "Videogröße" im
ffmpeg-utils-Handbuch. Der Standardwert ist "640x480".
start_scale
Stellen Sie den anfänglichen Skalenwert ein. Der Standardwert ist 3.0.
start_x
Legen Sie die anfängliche x-Position fest. Muss ein Gleitkommawert zwischen -100 und 100 sein.
Der Standardwert ist -0.743643887037158704752191506114774.
start_y
Legen Sie die anfängliche y-Position fest. Muss ein Gleitkommawert zwischen -100 und 100 sein.
Der Standardwert ist -0.131825904205311970493132056385139.
mptestrc
Generieren Sie verschiedene Testmuster, wie sie vom MPlayer-Testfilter generiert werden.
Die Größe des generierten Videos ist fest und beträgt 256x256. Diese Quelle ist nützlich in
insbesondere zum Testen von Codierungsfunktionen.
Diese Quelle akzeptiert die folgenden Optionen:
Bewertung, r
Geben Sie die Bildrate des Quellvideos als Anzahl der pro erzeugten Bilder an
zweite. Es muss ein String im Format sein Frame_Rate_num/Frame_Rate_Den, eine ganze Zahl
Zahl, eine Gleitkommazahl oder eine gültige Abkürzung für die Videobildrate. Der Standard
Wert ist "25".
Dauer, d
Legen Sie die Dauer des Quellvideos fest. Sehen Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell für die akzeptierte Syntax.
Wenn nicht angegeben oder die angegebene Dauer negativ ist, soll das Video sein
für immer generiert.
Test t
Legen Sie die Nummer oder den Namen des durchzuführenden Tests fest. Unterstützte Tests sind:
dc_luma
dc_chroma
freq_luma
Frequenz_Chroma
amp_luma
amp_chroma
Cbp
mv
ring1
ring2
alle
Der Standardwert ist "all", der die Liste aller Tests durchläuft.
Einige Beispiele:
mptestsrc=t=dc_luma
erzeugt ein "dc_luma" Testmuster.
frei0r_src
Geben Sie eine freie Quelle an.
Um die Kompilierung dieses Filters zu aktivieren, müssen Sie den frei0r-Header installieren und konfigurieren
FFmpeg mit "--enable-frei0r".
Diese Quelle akzeptiert die folgenden Parameter:
Größe
Die Größe des zu generierenden Videos. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell.
Framerate
Die Framerate des generierten Videos. Es kann ein String der Form . sein num/am oder eine
Abkürzung für die Bildrate.
Filtername
Der Name der frei0r-Quelle, die geladen werden soll. Weitere Informationen zu frei0r und wie
Um die Parameter einzustellen, lesen Sie die frei0r Abschnitt in der Videofilter-Dokumentation.
filter_params
Eine durch '|' getrennte Liste von Parametern, die an die frei0r-Quelle übergeben werden.
Zum Beispiel, um eine frei0r partik0l Quelle mit einer Größe von 200x200 und einer Bildrate von 10 . zu generieren
die dem Overlay-Filter-Haupteingang überlagert wird:
frei0r_src=size=200x200:framerate=10:filter_name=partik0l:filter_params=1234 [Overlay]; [in][Überlagerung] Überlagerung
life
Erzeuge ein Lebensmuster.
Diese Quelle basiert auf einer Verallgemeinerung des Lebensspiels von John Conway.
Die Quelleneingabe stellt ein Lebensraster dar, jedes Pixel stellt eine Zelle dar, die in einer sein kann
von zwei möglichen Zuständen, lebendig oder tot. Jede Zelle interagiert mit ihren acht Nachbarn,
Dies sind die Zellen, die horizontal, vertikal oder diagonal benachbart sind.
Bei jeder Interaktion entwickelt sich das Gitter gemäß der angenommenen Regel, die die
Anzahl der benachbarten lebenden Zellen, die eine Zelle am Leben bleiben oder geboren werden lassen. Der regieren zu erhalten
ermöglicht es, die zu übernehmende Regel anzugeben.
Diese Quelle akzeptiert die folgenden Optionen:
Dateiname, f
Legen Sie die Datei fest, aus der der anfängliche Rasterzustand gelesen werden soll. In der Datei wird jede nicht-
Whitespace-Zeichen gelten als lebendige Zelle, und Newline wird verwendet, um die
Ende jeder Reihe.
Wenn diese Option nicht angegeben ist, wird das Anfangsraster zufällig generiert.
Bewertung, r
Stellen Sie die Videorate ein, d. h. die Anzahl der Bilder, die pro Sekunde erzeugt werden. Standard ist 25.
random_fill_ratio, Verhältnis
Legen Sie das zufällige Füllverhältnis für das anfängliche Zufallsraster fest. Es ist eine Gleitkommazahl
Wert im Bereich von 0 bis 1, standardmäßig 1/PHI. Sie wird ignoriert, wenn eine Datei angegeben wird.
random_seed, Samen
Setzt den Seed zum Füllen des anfänglichen Zufallsrasters, muss eine ganze Zahl zwischen sein
0 und UINT32_MAX. Wenn nicht angegeben oder explizit auf -1 gesetzt, versucht der Filter,
Verwenden Sie einen guten Zufalls-Seed auf Best-Effort-Basis.
regieren
Legen Sie die Lebensregel fest.
Eine Regel kann mit einem Code der Art "S ." angegeben werdenNS/BNB", wo NS und NB sind
Zahlenfolgen im Bereich 0-8, NS gibt die Anzahl der lebenden Nachbarzellen an
die eine lebende Zelle am Leben halten lassen, und NB die Anzahl der lebenden Nachbarzellen, die
eine tote Zelle zum Leben erwecken (dh "geboren"). "s" und "b" können an Ort und Stelle verwendet werden
von "S" bzw. "B".
Alternativ kann eine Regel durch eine 18-Bit-Ganzzahl angegeben werden. Die 9 höherwertigen Bits sind
Wird verwendet, um den nächsten Zellzustand zu codieren, wenn er für jede Anzahl von lebenden Nachbarn lebt
Zellen, die niederwertigen Bits spezifizieren die Regel für das "Geboren" neuer Zellen. Bits höherer Ordnung
für eine höhere Anzahl von Nachbarzellen codieren. Zum Beispiel die Zahl 6153 =
"(12<<9)+9" gibt eine Stay-Alive-Regel von 12 und eine Born-Regel von 9 an, was entspricht
zu "S23/B03".
Der Standardwert ist "S23/B3", die ursprüngliche Spiel-des-Lebens-Regel von Conway und wird
hält eine Zelle am Leben, wenn sie 2 oder 3 lebende Nachbarzellen hat, und wird eine neue Zelle geboren, wenn
Es gibt drei lebende Zellen um eine tote Zelle.
Größe, s
Legen Sie die Größe des Ausgabevideos fest. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell.
If Dateinamen angegeben ist, ist die Größe standardmäßig auf die gleiche Größe der Eingabe eingestellt
Datei. Wenn Größe gesetzt ist, muss sie die in der Eingabedatei angegebene Größe enthalten, und die
Das in dieser Datei definierte Anfangsraster wird im größeren resultierenden Bereich zentriert.
Wenn kein Dateiname angegeben wird, ist der Größenwert standardmäßig "320x240" (verwendet für a
zufällig generiertes Anfangsraster).
Stich
Wenn auf 1 gesetzt, nähen Sie die linke und rechte Gitterkante zusammen und die obere und untere
auch Kanten. Standardmäßig auf 1.
Schimmel
Zellenformgeschwindigkeit einstellen. Wenn gesetzt, geht eine tote Zelle von Tod_Farbe zu Schimmel_Farbe mit
Schritt von Schimmel. Schimmel kann einen Wert von 0 bis 255 haben.
leben_farbe
Legen Sie die Farbe von lebenden (oder neugeborenen) Zellen fest.
Tod_Farbe
Legen Sie die Farbe der toten Zellen fest. Wenn Schimmel gesetzt ist, ist dies die erste Farbe, die verwendet wird, um darzustellen
eine tote Zelle.
Schimmel_Farbe
Schimmelfarbe einstellen, für definitiv abgestorbene und verschimmelte Zellen.
Die Syntax dieser 3 Farboptionen finden Sie im Abschnitt "Farbe" in den ffmpeg-utils
Handbuch.
Beispiele
· Lesen Sie ein Raster von Anleitungen, und zentrieren Sie es auf einem Raster der Größe 300 x 300 Pixel:
Leben=f=Muster:s=300x300
· Generieren Sie ein zufälliges Raster der Größe 200x200 mit einem Füllverhältnis von 2/3:
Leben=Verhältnis=2/3:s=200x200
· Geben Sie eine benutzerdefinierte Regel zum Entwickeln eines zufällig generierten Rasters an:
Leben=Regel=S14/B34
· Vollständiges Beispiel mit Slow-Death-Effekt (Schimmel) mit ffplay:
ffplay -f lavfi life=s=300x200:mold=10:r=60:ratio=0.1:death_color=#C83232:life_color=#00ff00,scale=1200:800:flags=16
allrgb, Allyuv, Farbe, Farbe, haldclutsrc, nullsrc, rgbtestrc, smptebars, smptehdbars, Testsrc
Die Quelle "allrgb" gibt Frames der Größe 4096x4096 aller RGB-Farben zurück.
Die Quelle "allyuv" gibt Frames der Größe 4096x4096 aller Yuv-Farben zurück.
Die Quelle "Farbe" liefert eine einheitlich farbige Eingabe.
Die Quelle "haldclutsrc" stellt eine Identität Hald CLUT bereit. Siehe auch halsklaue Filter.
Die Quelle "nullsrc" gibt unverarbeitete Videoframes zurück. Es ist hauptsächlich nützlich, angestellt zu sein
in Analyse-/Debugging-Tools oder als Quelle für Filter, die die Eingabedaten ignorieren.
Die Quelle "rgbtestsrc" generiert ein RGB-Testmuster, das für die Erkennung von RGB vs. BGR . nützlich ist
Probleme. Sie sollten einen roten, grünen und blauen Streifen von oben nach unten sehen.
Die Quelle "smptebars" generiert ein Farbbalkenmuster basierend auf dem SMPTE-Engineering
Richtlinie EG 1-1990.
Die Quelle "smptehdbars" generiert ein Farbbalkenmuster basierend auf der SMPTE RP 219-2002.
Die Quelle "testsrc" erzeugt ein Testvideomuster, das ein Farbmuster zeigt, ein Scrollen
Farbverlauf und ein Zeitstempel. Dies ist hauptsächlich für Testzwecke gedacht.
Die Quellen akzeptieren die folgenden Parameter:
Farbe, Farbe, c
Geben Sie die Farbe der Quelle an, die nur in der Quelle "Farbe" verfügbar ist. Für die Syntax
dieser Option überprüfen Sie den Abschnitt "Farbe" im ffmpeg-utils-Handbuch.
Grad des
Geben Sie den Pegel der Hald CLUT an, die nur in der Quelle "haldclutsrc" verfügbar ist. EIN
Level von "N" erzeugt ein Bild von "N*N*N" von "N*N*N" Pixeln, das als Identität verwendet wird
Matrix für 3D-Lookup-Tabellen. Jede Komponente ist auf einer "1/(N*N)"-Skala kodiert.
Größe, s
Geben Sie die Größe des Quellvideos an. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell. Der Standardwert ist "320x240".
Diese Option ist beim Filter "haldclutsrc" nicht verfügbar.
Bewertung, r
Geben Sie die Bildrate des Quellvideos als Anzahl der pro erzeugten Bilder an
zweite. Es muss ein String im Format sein Frame_Rate_num/Frame_Rate_Den, eine ganze Zahl
Zahl, eine Gleitkommazahl oder eine gültige Abkürzung für die Videobildrate. Der Standard
Wert ist "25".
sar Legen Sie das Beispielseitenverhältnis des Quellvideos fest.
Dauer, d
Legen Sie die Dauer des Quellvideos fest. Sehen Uhrzeit Dauer Abschnitt in
ffmpeg-utils(1) manuell für die akzeptierte Syntax.
Wenn nicht angegeben oder die angegebene Dauer negativ ist, soll das Video sein
für immer generiert.
Dezimalstellen, n
Legen Sie die Anzahl der Dezimalstellen fest, die im Zeitstempel angezeigt werden sollen, nur verfügbar in "testsrc"
Quelle.
Der angezeigte Zeitstempelwert entspricht dem ursprünglichen Zeitstempelwert
multipliziert mit der Zehnerpotenz des angegebenen Wertes. Der Standardwert ist 10.
Zum Beispiel folgendes:
testsrc=duration=5.3:size=qcif:rate=10
erzeugt ein Video mit einer Dauer von 5.3 Sekunden, mit einer Größe von 176x144 und einer Bildrate
von 10 Bildern pro Sekunde.
Die folgende Diagrammbeschreibung erzeugt eine rote Quelle mit einer Opazität von 0.2, mit
Größe "qcif" und einer Bildrate von 10 Bildern pro Sekunde.
Farbe=c=[E-Mail geschützt] :s=qcif:r=10
Soll der Eingabeinhalt ignoriert werden, kann "nullsrc" verwendet werden. Der folgende Befehl
erzeugt Rauschen in der Luminanzebene durch Verwendung des "geq"-Filters:
nullsrc=s=256x256, geq=zufällig(1)*255:128:128
Befehle
Die Quelle "color" unterstützt die folgenden Befehle:
c, Farbe
Legen Sie die Farbe des erstellten Bildes fest. Akzeptiert die gleiche Syntax des entsprechenden Farbe
.
VIDEO SPÜLEN
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Videosenken.
Puffersenke
Puffern Sie Videoframes und stellen Sie sie am Ende des Filterdiagramms zur Verfügung.
Diese Senke ist hauptsächlich für den programmatischen Gebrauch gedacht, insbesondere über die Schnittstelle
definiert in libavfilter/buffersink.h oder das Optionssystem.
Es akzeptiert einen Zeiger auf eine AVBufferSinkContext-Struktur, die die eingehenden . definiert
Pufferformate, die als undurchsichtiger Parameter an "avfilter_init_filter" übergeben werden für
Initialisierung.
Nullsenke
Null-Videosenke: Machen Sie absolut nichts mit dem Eingabevideo. Es ist hauptsächlich nützlich als
Vorlage und zur Verwendung in Analyse-/Debugging-Tools.
MULTIMEDIA FILTER
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Multimediafilter.
Aphasemeter
Wandeln Sie Eingangsaudio in einen Videoausgang um und zeigen Sie die Audiophase an.
Der Filter akzeptiert die folgenden Optionen:
Bewertung, r
Stellen Sie die Ausgabe-Framerate ein. Der Standardwert ist 25.
Größe, s
Legen Sie die Videogröße für die Ausgabe fest. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell. Der Standardwert ist "800x400".
rc
gc
bc Geben Sie den Rot-, Grün- und Blaukontrast an. Standardwerte sind 2, 7 und 1. Zulässiger Bereich
ist "[0, 255]".
mpc Legen Sie die Farbe fest, die zum Zeichnen der Medianphase verwendet wird. Wenn die Farbe "keine" ist, ist dies
Standardmäßig wird kein Median-Phasenwert gezeichnet.
Der Filter exportiert auch die Frame-Metadaten "lavfi.aphasemeter.phase", die den Mittelwert darstellen
Phase des aktuellen Audioframes. Der Wert liegt im Bereich "[-1, 1]". Die "-1" bedeutet links und rechts
Kanäle sind vollständig phasenverschoben und 1 bedeutet, dass Kanäle phasengleich sind.
Vektorskop
Wandeln Sie Eingangsaudio in einen Videoausgang um, der den Audiovektorbereich darstellt.
Der Filter wird verwendet, um den Unterschied zwischen den Kanälen des Stereo-Audiostreams zu messen. EIN
monoaurales Signal, bestehend aus identischem linken und rechten Signal, ergibt gerades
vertikale Linie. Jede Stereotrennung ist als Abweichung von dieser Linie sichtbar, wodurch ein
Lissajous-Figur. Wenn die gerade (oder davon abweichende) aber horizontale Linie erscheint, ist dies
zeigt an, dass der linke und der rechte Kanal phasenverschoben sind.
Der Filter akzeptiert die folgenden Optionen:
Modus m
Stellen Sie den Vektorskopmodus ein.
Verfügbare Werte sind:
Lissajous
Lissajous um 45 Grad gedreht.
lissajous_xy
Wie oben, aber nicht gedreht.
polar
Form ähnlich einem halben Kreis.
Standardwert ist Lissajous.
Größe, s
Legen Sie die Videogröße für die Ausgabe fest. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell. Der Standardwert ist "400x400".
Bewertung, r
Stellen Sie die Ausgabe-Framerate ein. Der Standardwert ist 25.
rc
gc
bc
ac Geben Sie den Rot-, Grün-, Blau- und Alpha-Kontrast an. Standardwerte sind 40, 160, 80 und
255. Zulässiger Bereich ist "[0, 255]".
rf
gf
bf
af Legen Sie Rot-, Grün-, Blau- und Alpha-Fade fest. Standardwerte sind 15, 10, 5 und 5.
Zulässiger Bereich ist "[0, 255]".
Zoom
Stellen Sie den Zoomfaktor ein. Der Standardwert ist 1. Erlaubter Bereich ist "[1, 10]".
Beispiele
· Komplettes Beispiel mit ffplay:
ffplay -f lavfi 'movie=input.mp3, asplit [a][out1];
[a] avectorscope=zoom=1.3:rc=2:gc=200:bc=10:rf=1:gf=8:bf=7 [out0]'
concat
Verketten Sie Audio- und Videostreams und fügen Sie sie nacheinander zusammen.
Der Filter arbeitet mit Segmenten synchronisierter Video- und Audiostreams. Alle Segmente müssen
haben die gleiche Anzahl von Streams jedes Typs, und das wird auch die Anzahl der Streams sein
am Ausgang.
Der Filter akzeptiert die folgenden Optionen:
n Legen Sie die Anzahl der Segmente fest. Standard ist 2.
v Legen Sie die Anzahl der ausgegebenen Videostreams fest, d. h. die Anzahl der Videostreams in
jedes Segment. Standard ist 1.
a Legen Sie die Anzahl der ausgegebenen Audiostreams fest, d. h. die Anzahl der Audiostreams in
jedes Segment. Standard ist 0.
unsicher
Unsicheren Modus aktivieren: Nicht fehlschlagen, wenn Segmente ein anderes Format haben.
Der Filter hat v+a Ausgänge: zuerst v Videoausgänge, dann a Audio-Ausgänge.
Es gibt nx(v+a) Eingaben: zuerst die Eingaben für das erste Segment, in der gleichen Reihenfolge wie die
Ausgänge, dann die Eingänge für das zweite Segment usw.
Ähnliche Streams haben aus verschiedenen Gründen nicht immer genau dieselbe Dauer
einschließlich Codec-Frame-Größe oder schlampiges Authoring. Aus diesem Grund verbundene synchronisierte
Streams (zB ein Video und seine Audiospur) sollten auf einmal verkettet werden. Der Konkat
Filter verwendet die Dauer des längsten Streams in jedem Segment (außer dem letzten),
und wenn nötig kürzere Audiostreams mit Stille auffüllen.
Damit dieser Filter richtig funktioniert, müssen alle Segmente beim Zeitstempel 0 beginnen.
Alle entsprechenden Streams müssen in allen Segmenten dieselben Parameter aufweisen; die Filterung
das System wählt automatisch ein gemeinsames Pixelformat für Videostreams und ein gemeinsames
Sample-Format, Sample-Rate und Kanal-Layout für Audiostreams, aber auch andere Einstellungen, wie z
als Auflösung, muss vom Benutzer explizit konvertiert werden.
Unterschiedliche Bildraten sind akzeptabel, führen jedoch zu einer variablen Bildrate bei der Ausgabe; Sein
Stellen Sie sicher, dass Sie die Ausgabedatei so konfigurieren, dass sie damit verarbeitet wird.
Beispiele
· Verketten Sie eine Eröffnung, eine Episode und ein Ende, alles in zweisprachiger Version (Video in
Stream 0, Audio in Stream 1 und 2):
ffmpeg -i Eröffnung.mkv -i Episode.mkv -i Endung.mkv -filter_complex \
'[0:0] [0:1] [0:2] [1:0] [1:1] [1:2] [2:0] [2:1] [2:2]
concat=n=3:v=1:a=2 [v] [a1] [a2]' \
-map '[v]' -map '[a1]' -map '[a2]' Ausgabe.mkv
· Verketten Sie zwei Teile, indem Sie Audio und Video getrennt behandeln, indem Sie den (a)Film verwenden
Quellen und Anpassen der Auflösung:
film=part1.mp4, scale=512:288 [v1] ; amovie=part1.mp4 [a1] ;
film=part2.mp4, scale=512:288 [v2] ; amovie=part2.mp4 [a2] ;
[v1] [v2] concat [outv] ; [a1] [a2] concat=v=0:a=1 [outa]
Beachten Sie, dass beim Stitch eine Desynchronisierung stattfindet, wenn die Audio- und Videostreams dies nicht tun
haben in der ersten Datei genau die gleiche Dauer.
ebur128
EBU R128 Scannerfilter. Dieser Filter nimmt einen Audiostream als Eingabe und gibt ihn aus
unverändert. Standardmäßig protokolliert es eine Nachricht mit einer Frequenz von 10 Hz mit dem Momentary
Lautheit (gekennzeichnet durch "M"), Kurzzeitlautstärke ("S"), Integrierte Lautheit ("I") und
Lautstärkebereich ("LRA").
Der Filter hat auch einen Videoausgang (siehe Video Option) mit einer Echtzeitgrafik zu
Beobachten Sie die Lautstärkeentwicklung. Die Grafik enthält die oben erwähnte protokollierte Nachricht,
es wird also nicht mehr gedruckt, wenn diese Option gesetzt ist, es sei denn, die ausführliche Protokollierung ist eingestellt.
Der Hauptgrafikbereich enthält die Kurzzeitlautstärke (3 Sekunden Analyse) und die
Anzeige rechts ist für die momentane Lautstärke (400 Millisekunden).
Mehr Informationen zur Loudness-Empfehlung EBU R128 auf
<http://tech.ebu.ch/loudness>.
Der Filter akzeptiert die folgenden Optionen:
Video
Aktivieren Sie den Videoausgang. Der Audiostream wird unverändert übergeben, unabhängig davon, ob diese Option aktiviert ist
eingestellt oder nein. Der Videostream ist der erste Ausgabestream, wenn er aktiviert ist. Standard ist
0.
Größe
Stellen Sie die Videogröße ein. Diese Option gilt nur für Videos. Für die Syntax dieser Option,
Überprüf den "Video Größe" Abschnitt in ffmpeg-utils manuell. Standard und Minimum
Auflösung ist "640x480".
Meter
Stellen Sie den EBU-Skalenmesser ein. Der Standardwert ist 9. Übliche Werte sind 9 bzw. 18 für
EBU-Skalenmesser +9 und EBU-Skalenmesser +18. Jeder andere ganzzahlige Wert zwischen diesem Bereich
ist erlaubt.
Metadaten
Legen Sie die Metadateninjektion fest. Wenn auf 1 gesetzt, wird der Audioeingang in 100 ms unterteilt
Ausgabeframes, von denen jeder verschiedene Lautheitsinformationen in Metadaten enthält. Alle
den Metadatenschlüsseln wird "lavfi.r128." vorangestellt.
Standard ist 0.
Framelog
Erzwingen Sie die Frame-Protokollierungsebene.
Verfügbare Werte sind:
Info
Informationsprotokollierungsebene
ausführlich
ausführliche Protokollierungsebene
Standardmäßig ist die Protokollierungsebene auf eingestellt Info. Wenn der Video oder unter der Metadaten Optionen sind
eingestellt, wechselt es zu ausführlich.
Haupt
Spitzenmodus(e) einstellen.
Verfügbare Modi können kumuliert werden (die Option ist ein "Flag"-Typ). Mögliche Werte sind:
keine
Deaktivieren Sie jeden Peak-Modus (Standard).
Sample
Aktivieren Sie den Sample-Peak-Modus.
Einfacher Peak-Modus auf der Suche nach dem höheren Sample-Wert. Es protokolliert eine Nachricht für
Sample-Peak (gekennzeichnet durch "SPK").
was immer dies auch sein sollte.
Aktivieren Sie den True-Peak-Modus.
Wenn aktiviert, erfolgt die Peak-Suche auf einer überabgetasteten Version des Eingabestreams
für eine bessere Spitzengenauigkeit. Es protokolliert eine Nachricht für True-Peak. (gekennzeichnet durch "TPK")
und True-Peak pro Frame (identifiziert durch "FTPK"). Dieser Modus erfordert einen Build mit
"libswresample".
Beispiele
· Echtzeit-Grafik mit ffplay, mit einem EBU-Skalenmesser +18:
ffplay -f lavfi -i "movie=input.mp3,ebur128=video=1:meter=18 [out0][out1]"
· Führen Sie eine Analyse durch mit ffmpeg:
ffmpeg -nostats -i input.mp3 -filter_complex ebur128 -f null -
verschachteln, verschachteln
Frames von mehreren Eingängen zeitlich verschachteln.
"interleave" arbeitet mit Videoeingängen, "ainterleave" mit Audio.
Diese Filter lesen Frames von mehreren Eingängen und senden den ältesten Frame in der Warteschlange an den
Ausgabe.
Eingabestreams müssen gut definierte, monoton ansteigende Frame-Zeitstempelwerte aufweisen.
Um einen Frame an die Ausgabe zu senden, müssen diese Filter mindestens einen Frame in die Warteschlange stellen
für jeden Eingang, so dass sie nicht funktionieren können, falls ein Eingang noch nicht abgeschlossen ist und nicht funktioniert
eingehende Frames empfangen.
Betrachten Sie zum Beispiel den Fall, dass eine Eingabe ein "Auswahl"-Filter ist, der Eingaben immer auslässt
Rahmen. Der "Interleave"-Filter liest weiterhin aus dieser Eingabe, wird es jedoch nie sein
in der Lage, neue Frames an den Ausgang zu senden, bis der Eingang ein Stream-Ende-Signal sendet.
Abhängig von der Eingangssynchronisation werden die Filter auch Frames verwerfen, falls ein Eingang
empfängt mehr Frames als die anderen und die Warteschlange ist bereits gefüllt.
Diese Filter akzeptieren die folgenden Optionen:
nb_eingaben, n
Stellen Sie die Anzahl der verschiedenen Eingänge ein, standardmäßig sind es 2.
Beispiele
· Verschachteln Sie Frames, die zu verschiedenen Streams gehören, mit ffmpeg:
ffmpeg -i bambi.avi -i pr0n.mkv -filter_complex "[0:v][1:v] interleave" out.avi
· Flimmernde Unschärfe-Effekt hinzufügen:
select='if(gt(zufällig(0), 0.2), 1, 2)':n=2 [tmp], boxblur=2:2, [tmp] interleave
Dauerwellen, apermen
Legen Sie Lese-/Schreibberechtigungen für die Ausgabeframes fest.
Diese Filter richten sich hauptsächlich an Entwickler, um den direkten Pfad im folgenden Filter zu testen
in der Filtergrafik.
Die Filter akzeptieren die folgenden Optionen:
Modus
Wählen Sie den Berechtigungsmodus aus.
Es akzeptiert die folgenden Werte:
keine
Nichts tun. Dies ist die Standardeinstellung.
ro Legen Sie alle Ausgabeframes schreibgeschützt fest.
rw Stellen Sie alle Ausgabeframes direkt beschreibbar ein.
Umschalten
Machen Sie den Frame schreibgeschützt, wenn er beschreibbar ist, und schreibbar, wenn er schreibgeschützt ist.
zufällig
Legen Sie jeden Ausgaberahmen schreibgeschützt oder zufällig beschreibbar fest.
Samen
Setzen Sie den Samen für die zufällig mode, muss eine ganze Zahl zwischen 0 und sein
"UINT32_MAX". Wenn nicht angegeben oder explizit auf "-1" gesetzt, versucht der Filter,
Verwenden Sie einen guten Zufalls-Seed auf Best-Effort-Basis.
Hinweis: Im Falle eines automatisch eingefügten Filters zwischen dem Berechtigungsfilter und dem folgenden,
die Berechtigung wird im folgenden Filter möglicherweise nicht wie erwartet empfangen. Einfügen von a
Format or aformat Filter vor dem Perms/Aperms-Filter kann dieses Problem vermeiden.
auswählen, auswählen
Wählen Sie Frames aus, die ausgegeben werden sollen.
Dieser Filter akzeptiert die folgenden Optionen:
Ausdruck, e
Set-Ausdruck, der für jeden Eingaberahmen ausgewertet wird.
Wenn der Ausdruck zu Null ausgewertet wird, wird der Frame verworfen.
Wenn das Bewertungsergebnis negativ oder NaN ist, wird der Frame an den ersten Ausgang gesendet;
andernfalls wird es mit dem Index "ceil(val)-1" an den Ausgang gesendet, vorausgesetzt, der Eingang
Index beginnt bei 0.
Beispielsweise entspricht ein Wert von 1.2 der Ausgabe mit dem Index "ceil(1.2)-1 = 2-1 =
1", das ist die zweite Ausgabe.
Ausgänge, n
Stellen Sie die Anzahl der Ausgänge ein. Der Ausgang, an den der ausgewählte Frame gesendet werden soll, basiert auf
das Ergebnis der Auswertung. Der Standardwert ist 1.
Der Ausdruck kann die folgenden Konstanten enthalten:
n Die (laufende) Nummer des gefilterten Frames, beginnend bei 0.
ausgewählt_n
Die (laufende) Nummer des ausgewählten Frames, beginnend bei 0.
vorherige_ausgewählte_n
Die fortlaufende Nummer des zuletzt ausgewählten Frames. Es ist NAN, wenn nicht definiert.
TB Die Zeitbasis der Eingabezeitstempel.
pts Der PTS (Presentation TimeStamp) des gefilterten Videoframes, ausgedrückt in TB Einheiten.
Es ist NAN, wenn nicht definiert.
t Der PTS des gefilterten Videoframes, ausgedrückt in Sekunden. Es ist NAN, wenn nicht definiert.
prev_pts
Der PTS des zuvor gefilterten Videoframes. Es ist NAN, wenn nicht definiert.
vorherige_ausgewählte_pts
Der PTS des letzten zuvor gefilterten Videoframes. Es ist NAN, wenn nicht definiert.
prev_ausgewählt_t
Der PTS des zuletzt ausgewählten Videoframes. Es ist NAN, wenn nicht definiert.
start_pts
Der PTS des ersten Videoframes im Video. Es ist NAN, wenn nicht definiert.
start_t
Die Zeit des ersten Videoframes im Video. Es ist NAN, wenn nicht definiert.
Bildtyp (Video nur)
Der Typ des gefilterten Frames. Es kann einen der folgenden Werte annehmen:
I
P
B
S
SI
SP
BI
interlace_typ (Video nur)
Der Frame-Interlace-Typ. Es kann einen der folgenden Werte annehmen:
PROGRESSIV
Der Frame ist progressiv (nicht interlaced).
OBEN ZUERST
Der Frame ist Top-Field-First.
UNTENFIRST
Der Rahmen ist mit dem unteren Halbbild zuerst.
verbraucht_sample_n (Audio nur)
die Anzahl der ausgewählten Samples vor dem aktuellen Frame
Proben_n (Audio nur)
die Anzahl der Samples im aktuellen Frame
Beispielrate (Audio nur)
die Eingangs-Samplerate
Haupt Dies ist 1, wenn der gefilterte Frame ein Keyframe ist, ansonsten 0.
Post die Position des gefilterten Frames in der Datei, -1 wenn die Informationen nicht verfügbar sind
(zB für synthetisches Video)
Szene (Video nur)
Wert zwischen 0 und 1, um eine neue Szene anzuzeigen; ein niedriger Wert spiegelt eine geringe Wahrscheinlichkeit wider
für den aktuellen Frame, um eine neue Szene einzuleiten, während ein höherer Wert den aktuellen
Rahmen ist eher einer (siehe das Beispiel unten)
Der Standardwert des Auswahlausdrucks ist "1".
Beispiele
· Wählen Sie alle Frames in der Eingabe aus:
wählen
Das obige Beispiel ist dasselbe wie:
auswählen=1
· Alle Frames überspringen:
auswählen=0
· Wählen Sie nur I-Frames aus:
select='eq(pict_type\,I)'
· Wählen Sie alle 100 ein Bild aus:
select='not(mod(n\,100))'
· Wählen Sie nur Bilder aus, die im Zeitintervall 10-20 enthalten sind:
select=zwischen(t\,10\,20)
· Wählen Sie nur I-Frames aus, die im Zeitintervall 10-20 enthalten sind:
select=zwischen(t\,10\,20)*eq(pict_type\,I)
· Bilder mit einem Mindestabstand von 10 Sekunden auswählen:
select='isnan(prev_selected_t)+gte(t-prev_selected_t\,10)'
· Verwenden Sie aselect, um nur Audioframes mit einer Sample-Nummer > 100 auszuwählen:
aselect='gt(samples_n\,100)'
· Erstellen Sie ein Mosaik der ersten Szenen:
ffmpeg -i video.avi -vf select='gt(scene\,0.4)',scale=160:120,tile -frames:v 1 preview.png
Vergleich Szene gegen einen Wert zwischen 0.3 und 0.5 ist im Allgemeinen eine vernünftige Wahl.
· Senden Sie gerade und ungerade Frames an separate Ausgänge und setzen Sie sie zusammen:
select=n=2:e='mod(n, 2)+1' [ungerade][gerade]; [ungerade] pad=h=2*ih [tmp]; [tmp][even] overlay=y=h
sendcmd, asendcmd
Senden Sie Befehle an Filter im Filtergraph.
Diese Filter lesen Befehle, die an andere Filter im Filtergraph gesendet werden sollen.
"sendcmd" muss zwischen zwei Videofiltern eingefügt werden, "asendcmd" muss dazwischen eingefügt werden
zwei Audiofilter, aber ansonsten verhalten sie sich gleich.
Die Angabe von Befehlen kann in den Filterargumenten mit dem Befehle
Option, oder in einer Datei, die von der Dateinamen .
Diese Filter akzeptieren die folgenden Optionen:
Befehle, c
Legen Sie die Befehle fest, die gelesen und an die anderen Filter gesendet werden sollen.
Dateiname, f
Legen Sie den Dateinamen der Befehle fest, die gelesen und an die anderen Filter gesendet werden sollen.
Befehle Syntax
Eine Befehlsbeschreibung besteht aus einer Folge von Intervallangaben, bestehend aus a
Liste von Befehlen, die ausgeführt werden sollen, wenn ein bestimmtes Ereignis in Bezug auf dieses Intervall auftritt.
Das auftretende Ereignis ist normalerweise die aktuelle Frame-Zeit, die eine bestimmte Zeit betritt oder verlässt
Intervall.
Ein Intervall wird durch die folgende Syntax angegeben:
[- ] ;
Das Zeitintervall wird durch die Starte das Spiel und ENDE Zeiten. ENDE ist optional und voreingestellt
zur maximalen Zeit.
Die aktuelle Framezeit wird innerhalb des angegebenen Intervalls berücksichtigt, wenn sie in enthalten ist
das Intervall [Starte das Spiel, ENDE), d. h. wenn die Zeit größer oder gleich ist Starte das Spiel und ein
weniger als ENDE.
BEFEHLE besteht aus einer Folge von einer oder mehreren Befehlsangaben, getrennt durch ",",
in Bezug auf dieses Intervall. Die Syntax einer Befehlsspezifikation ist gegeben durch:
[ ]
FLAGGEN ist optional und gibt die Art der Ereignisse an, die sich auf das Zeitintervall beziehen, das
ermöglicht das Senden des angegebenen Befehls und muss eine Folge von Identifier-Flags sein, die nicht null ist
getrennt durch "+" oder "|" und zwischen "[" und "]" eingeschlossen.
Folgende Flags werden erkannt:
eingeben
Der Befehl wird gesendet, wenn der aktuelle Frame-Zeitstempel in das angegebene Intervall eintritt. In
mit anderen Worten, der Befehl wird gesendet, wenn der vorherige Frame-Zeitstempel nicht im
gegebenen Intervall, und der Strom ist.
verlassen
Der Befehl wird gesendet, wenn der aktuelle Frame-Zeitstempel das angegebene Intervall verlässt. In
mit anderen Worten, der Befehl wird gesendet, wenn der vorherige Frame-Zeitstempel im angegebenen Wert war
Intervall, und der Strom ist es nicht.
If FLAGGEN nicht angegeben ist, wird ein Standardwert von "[enter]" angenommen.
TARGET gibt das Ziel des Befehls an, normalerweise den Namen der Filterklasse oder a
spezifischer Name der Filterinstanz.
COMMAND gibt den Namen des Befehls für den Zielfilter an.
ARG ist optional und gibt die optionale Liste von Argumenten für die angegebene an COMMAND.
Zwischen einer Intervallangabe und einer anderen, Leerzeichen oder Zeichenfolgen
beginnend mit "#" bis zum Zeilenende werden ignoriert und können zur Kommentierung von Kommentaren verwendet werden.
Es folgt eine vereinfachte BNF-Beschreibung der Befehlsspezifikationssyntax:
::= "eingeben" | "verlassen"
::= [(+|"|") ]
::= ["[" "]"] [ ]
::= [, ]
::= [- ]
::= [; ]
Beispiele
· Geben Sie die Audiotempoänderung bei Sekunde 4 an:
asendcmd=c='4.0 atempo tempo 1.5',atempo
· Geben Sie eine Liste von Zeichentext- und Farbtonbefehlen in einer Datei an.
# Text im Intervall 5-10 . anzeigen
5.0-10.0 [enter] drawtext reinit 'fontfile=FreeSerif.ttf:text=hallo world',
[leave] drawtext reinit 'fontfile=FreeSerif.ttf:text=';
# Entsättigen Sie das Bild im Intervall von 15-20
15.0-20.0 [Eingabe] Farbton 0,
[enter] drawtext reinit 'fontfile=FreeSerif.ttf:text=nocolor',
[lassen] Farbton s 1,
[leave] drawtext reinit 'fontfile=FreeSerif.ttf:text=color';
# Wenden Sie einen exponentiellen Sättigungs-Ausblendeffekt an, beginnend mit der Zeit 25
25 [Eingabe] Hue s exp(25-t)
Ein Filtergraph, der es ermöglicht, die obige Befehlsliste, die in einer Datei gespeichert ist, zu lesen und zu verarbeiten
test.cmd, kann angegeben werden mit:
sendcmd=f=test.cmd,drawtext=fontfile=FreeSerif.ttf:text='',hue
Einstellungen, astpts
Ändern Sie den PTS (Präsentationszeitstempel) der Eingabeframes.
"setpts" funktioniert bei Video-Frames, "asetpts" bei Audio-Frames.
Dieser Filter akzeptiert die folgenden Optionen:
ausdr
Der Ausdruck, der für jeden Frame ausgewertet wird, um seinen Zeitstempel zu erstellen.
Der Ausdruck wird über die eval-API ausgewertet und kann die folgenden Konstanten enthalten:
FRAME_RATE
Bildrate, nur für Videos mit konstanter Bildrate definiert
PTS Der Präsentationszeitstempel in der Eingabe
N Die Zählung des Eingabeframes für Video oder die Anzahl der verbrauchten Samples, nicht
einschließlich des aktuellen Frames für Audio, beginnend bei 0.
NB_CONSUMED_SAMPLES
Die Anzahl der konsumierten Samples, ohne den aktuellen Frame (nur Audio)
NB_SAMPLES, S
Die Anzahl der Samples im aktuellen Frame (nur Audio)
BEISPIELRATE, SR
Die Audio-Samplerate.
STARTPTS
Der PTS des ersten Frames.
STARTT
die Zeit in Sekunden des ersten Frames
VERNETZT
Geben Sie an, ob der aktuelle Frame interlaced ist.
T die Zeit in Sekunden des aktuellen Frames
POS ursprüngliche Position in der Datei des Rahmens oder undefiniert, wenn für den aktuellen nicht definiert
Rahmen
PREV_INPTS
Der vorherige Eingabe-PTS.
PREV_INT
vorherige Eingabezeit in Sekunden
PREV_OUTPTS
Der vorherige Ausgabe-PTS.
PREV_OUTT
vorherige Ausgabezeit in Sekunden
RTCTIME
Die Zeit der Wanduhr (RTC) in Mikrosekunden. Dies ist veraltet, verwenden Sie Zeit(0) statt.
RTCSTART
Die Wanduhrzeit (RTC) zu Beginn des Films in Mikrosekunden.
TB Die Zeitbasis der Eingabezeitstempel.
Beispiele
· Beginnen Sie mit dem PTS-Zählen von Null
setpts=PTS-STARTPTS
· Zeitraffereffekt anwenden:
setpts=0.5*PTS
· Zeitlupeneffekt anwenden:
setpts=2.0*PTS
· Feste Rate von 25 Bildern pro Sekunde einstellen:
Sätze=N/(25*TB)
· Feste Rate 25 fps mit etwas Jitter einstellen:
setpts='1/(25*TB) * (N + 0.05 * sin(N*2*PI/25))'
· Wenden Sie einen Offset von 10 Sekunden auf den Eingangs-PTS an:
setpts=PTS+10/TB
· Zeitstempel aus einer "Live-Quelle" generieren und auf die aktuelle Zeitbasis umbasieren:
setpts='(RTCTIME - RTCSTART) / (TB * 1000000)'
· Zeitstempel durch Zählen von Samples generieren:
asetpts=N/SR/TB
setb, asettb
Legen Sie die Zeitbasis fest, die für die Zeitstempel der Ausgabeframes verwendet werden soll. Es ist hauptsächlich zum Testen nützlich
Konfiguration der Zeitbasis.
Es akzeptiert die folgenden Parameter:
Ausdruck, tb
Der Ausdruck, der in die Ausgabezeitbasis ausgewertet wird.
Der Wert für tb ist ein arithmetischer Ausdruck, der ein rationales repräsentiert. Der Ausdruck kann
enthalten die Konstanten "AVTB" (die Standardzeitbasis), "intb" (die Eingabezeitbasis) und "sr"
(die Abtastrate, nur Audio). Der Standardwert ist "intb".
Beispiele
· Stellen Sie die Zeitbasis auf 1/25:
settb=expr=1/25
· Stellen Sie die Zeitbasis auf 1/10:
setb=expr=0.1
· Stellen Sie die Zeitbasis auf 1001/1000:
settb=1+0.001
· Stellen Sie die Zeitbasis auf 2*intb ein:
settb=2*intb
· Legen Sie den Standardwert für die Zeitbasis fest:
settb=AVTB
showcqt
Wandeln Sie Eingangsaudio in einen Videoausgang um, der das Frequenzspektrum logarithmisch darstellt
(unter Verwendung konstanter Q-Transformation mit Brown-Puckette-Algorithmus), mit musikalischer Tonskala, von
E0 bis D#10 (10 Oktaven).
Der Filter akzeptiert die folgenden Optionen:
Volumen
Geben Sie den Ausdruck für das Transformationsvolumen (Multiplikator) an. Der Ausdruck kann enthalten
Variablen:
Frequenz, Frequenz, f
die Frequenz, bei der die Transformation ausgewertet wird
Zeitschaltuhr, tc
Wert der Timeclamp-Option
und Funktionen:
a_gewichtung(f)
A-Bewertung gleicher Lautstärke
b_gewichtung(f)
B-Bewertung gleicher Lautstärke
c_gewichtung(f)
C-Bewertung gleicher Lautstärke
Der Standardwert ist 16.
tlänge
Geben Sie den Ausdruck für die Transformationslänge an. Der Ausdruck kann Variablen enthalten:
Frequenz, Frequenz, f
die Frequenz, bei der die Transformation ausgewertet wird
Zeitschaltuhr, tc
Wert der Timeclamp-Option
Der Standardwert ist "384/f*tc/(384/f+tc)".
Zeitschaltuhr
Geben Sie die Transformationszeitspanne an. Bei niedriger Frequenz gibt es einen Kompromiss zwischen der Genauigkeit
im Zeit- und Frequenzbereich. Wenn timeclamp niedriger ist, ist das Ereignis im Zeitbereich
genauer dargestellt (zB schnelle Bassdrum), sonst Ereignis in Frequenz
Domäne wird genauer dargestellt (z. B. Bassgitarre). Akzeptabler Wert ist [0.1,
1.0]. Der Standardwert ist 0.17.
Koeffizientenklemme
Geben Sie die Transformations-Koeffizientenklemme an. Wenn coeffclamp niedriger ist, ist die Transformation genauer,
andernfalls ist die Transformation schneller. Der zulässige Wert ist [0.1, 10.0]. Der Standardwert ist 1.0.
Gamma
Gamma angeben. Niedrigeres Gamma macht das Spektrum kontrastreicher, höheres Gamma macht das
Spektrum mit mehr Reichweite. Der zulässige Wert ist [1.0, 7.0]. Der Standardwert ist 3.0.
gamma2
Geben Sie das Gamma des Balkendiagramms an. Der zulässige Wert ist [1.0, 7.0]. Der Standardwert ist 1.0.
Schriftdatei
Geben Sie die Schriftartdatei für die Verwendung mit Freetype an. Wenn nicht angegeben, verwenden Sie eingebettete Schriftarten.
Schriftfarbe
Geben Sie den Ausdruck für die Schriftfarbe an. Dies ist ein arithmetischer Ausdruck, der zurückgeben sollte
ganzzahliger Wert 0xRRGGBB. Der Ausdruck kann Variablen enthalten:
Frequenz, Frequenz, f
die Frequenz, bei der die Transformation ausgewertet wird
Zeitschaltuhr, tc
Wert der Timeclamp-Option
und Funktionen:
Midi (w)
Midi-Zahl der Frequenz f, einige Midi-Zahlen: E0(16) C1(24) C2(36) A4(69)
r(x), g(x), b(x)
Rot-, Grün- und Blauwert der Intensität x
Standardwert ist "st(0, (midi(f)-59.5)/12); st(1, if(zwischen(ld(0),0,1),
0.5-0.5*cos(2*PI*ld(0)), 0)); R(1-ld(1)) + b(ld(1))"
fullhd
Bei Einstellung auf 1 (Standard) beträgt die Videogröße 1920 x 1080 (Full HD), bei Einstellung auf 0 wird die
Videogröße ist 960x540. Verwenden Sie diese Option, um die CPU-Auslastung zu verringern.
fps Videofps angeben. Der Standardwert ist 25.
zählen
Geben Sie die Anzahl der Transformationen pro Frame an, damit es fps*count-Transformationen pro Sekunde gibt.
Beachten Sie, dass die Audiodatenrate durch fps*count teilbar sein muss. Der Standardwert ist 6.
Beispiele
· Audio abspielen, während das Spektrum angezeigt wird:
ffplay -f lavfi 'movie=a.mp3, asplit [a][out1]; [a] showcqt [out0]'
· Wie oben, jedoch mit einer Bildrate von 30 fps:
ffplay -f lavfi 'movie=a.mp3, asplit [a][out1]; [a] showcqt=fps=30:count=5 [out0]'
· Spielen mit 960 x 540 und geringerer CPU-Auslastung:
ffplay -f lavfi 'movie=a.mp3, asplit [a][out1]; [a] showcqt=fullhd=0:count=3 [out0]'
· A1 und seine Harmonischen: A1, A2, (nahe)E3, A3:
ffplay -f lavfi 'aevalsrc=0.1*sin(2*PI*55*t)+0.1*sin(4*PI*55*t)+0.1*sin(6*PI*55*t)+0.1*sin(8*PI*55*t),
asplit[a][out1]; [a] showcqt [out0]'
· Wie oben, jedoch mit höherer Genauigkeit im Frequenzbereich (und langsamer):
ffplay -f lavfi 'aevalsrc=0.1*sin(2*PI*55*t)+0.1*sin(4*PI*55*t)+0.1*sin(6*PI*55*t)+0.1*sin(8*PI*55*t),
asplit[a][out1]; [a] showcqt=timeclamp=0.5 [out0]'
· B-Bewertung gleicher Lautstärke
Volumen=16*b_Gewichtung(f)
· Niedrigerer Q-Faktor
tlänge=100/f*tc/(100/f+tc)
· Benutzerdefinierte Schriftfarbe, C-Note ist grün gefärbt, andere sind blau gefärbt
fontcolor='if(mod(floor(midi(f)+0.5),12), 0x0000FF, g(1))'
· Benutzerdefiniertes Gamma, jetzt ist das Spektrum linear zur Amplitude.
gamma=2:gamma2=2
Showfreqs
Wandeln Sie Eingangsaudio in Videoausgang um, der das Audioleistungsspektrum darstellt. Audio
die Amplitude befindet sich auf der Y-Achse, während die Frequenz auf der X-Achse liegt.
Der Filter akzeptiert die folgenden Optionen:
Größe, s
Geben Sie die Größe des Videos an. Die Syntax dieser Option finden Sie im "Video Größe" Abschnitt
in ffmpeg-utils manuell. Der Standardwert ist "1024 x 512".
Modus
Anzeigemodus einstellen. Damit legen Sie fest, wie jedes Frequenz-Bin dargestellt wird.
Es akzeptiert die folgenden Werte:
Linie
Bar
Punkt
Standard ist "bar".
eine Skala
Amplitudenskala einstellen.
Es akzeptiert die folgenden Werte:
lin Lineare Skalierung.
sqrt
Quadratwurzelskala.
cbrt
Kubische Wurzelskala.
Log Logarithmische Darstellung.
Standard ist "log".
fscale
Frequenzskala einstellen.
Es akzeptiert die folgenden Werte:
lin Lineare Skalierung.
Log Logarithmische Darstellung.
rlog
Umgekehrte logarithmische Skala.
Standard ist "lin".
win_size
Fenstergröße einstellen.
Es akzeptiert die folgenden Werte:
w16
w32
w64
w128
w256
w512
w1024
w2048
w4096
w8192
w16384
w32768
w65536
Standard ist "w2048"
win_func
Fensterfunktion einstellen.
Es akzeptiert die folgenden Werte:
richtig
Bartlett
Hanning
hämmern
schwarzer Mann
welch
Flattop
Bharris
groß
bhann
ihre
verrückt
Standard ist "hanning".
überlappen
Fensterüberlappung einstellen. Im Bereich "[0, 1]". Der Standardwert ist 1, was eine optimale Überlappung für . bedeutet
ausgewählte Fensterfunktion wird ausgewählt.
Mittelung
Zeitmittelung einstellen. Wenn Sie dies auf 0 setzen, werden die aktuellen maximalen Spitzenwerte angezeigt. Standard ist
1, was bedeutet, dass die Zeitmittelung deaktiviert ist.
Farbe
Geben Sie eine Liste von Farben an, die durch Leerzeichen oder '|' getrennt sind. die verwendet wird, um den Kanal zu zeichnen
Frequenzen. Nicht erkannte oder fehlende Farben werden durch weiße Farbe ersetzt.
Showspektrum
Wandeln Sie Eingangsaudio in einen Videoausgang um, der das Audiofrequenzspektrum darstellt.
Der Filter akzeptiert die folgenden Optionen:
Größe, s
Geben Sie die Videogröße für die Ausgabe an. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell. Der Standardwert ist "640x512".
Schlitten
Geben Sie an, wie das Spektrum entlang des Fensters gleiten soll.
Es akzeptiert die folgenden Werte:
ersetzen
die Samples beginnen wieder links, wenn sie rechts ankommen
blättern
die Proben scrollen von rechts nach links
Vollbild
Frames werden nur produziert, wenn die Samples das richtige erreichen
Der Standardwert ist "ersetzen".
Modus
Anzeigemodus angeben.
Es akzeptiert die folgenden Werte:
kombiniert
alle Kanäle werden in derselben Zeile angezeigt
getrennte
alle Kanäle werden in separaten Zeilen angezeigt
Standardwert ist kombiniert.
Farbe
Geben Sie den Anzeigefarbmodus an.
Es akzeptiert die folgenden Werte:
Kanal
jeder Kanal wird in einer eigenen Farbe angezeigt
Intensität
jeder Kanal wird im gleichen Farbschema angezeigt
Standardwert ist Kanal.
Treppe
Geben Sie die Skala an, die zum Berechnen der Intensitätsfarbwerte verwendet wird.
Es akzeptiert die folgenden Werte:
lin linear
sqrt
Quadratwurzel, Standard
cbrt
Kubikwurzel
Log logarithmisch
Standardwert ist sqrt.
Sättigung
Stellen Sie den Sättigungsmodifikator für die angezeigten Farben ein. Negative Werte bieten Alternative
Farbschema. 0 ist überhaupt keine Sättigung. Die Sättigung muss im Bereich von [-10.0, 10.0] liegen.
Der Standardwert ist 1.
win_func
Fensterfunktion einstellen.
Es akzeptiert die folgenden Werte:
keine
Keine Probenvorverarbeitung (erwarten Sie nicht, dass dies schneller ist)
hann
Hann Fenster
hämmern
Hamming-Fenster
schwarzer Mann
Blackman-Fenster
Der Standardwert ist "hann".
Die Verwendung ist der des showwaves-Filters sehr ähnlich; siehe die Beispiele in diesem Abschnitt.
Beispiele
· Großes Fenster mit logarithmischer Farbskalierung:
showspectrum=s=1280x480:scale=log
· Vollständiges Beispiel für ein farbiges und gleitendes Spektrum pro Kanal mit ffplay:
ffplay -f lavfi 'movie=input.mp3, asplit [a][out1];
[a] showspectrum=mode=separate:color=intensity:slide=1:scale=cbrt [out0]'
Showvolumen
Wandeln Sie die Eingangsaudiolautstärke in eine Videoausgabe um.
Der Filter akzeptiert die folgenden Optionen:
Bewertung, r
Videorate einstellen.
b Rahmenbreite einstellen, zulässiger Bereich ist [0, 5]. Standard ist 1.
w Kanalbreite einstellen, zulässiger Bereich ist [40, 1080]. Der Standardwert ist 400.
h Kanalhöhe einstellen, zulässiger Bereich ist [1, 100]. Standard ist 20.
f Fade einstellen, zulässiger Bereich ist [1, 255]. Standard ist 20.
c Stellen Sie den Farbausdruck für die Lautstärke ein.
Der Ausdruck kann die folgenden Variablen verwenden:
VOLUME
Aktuelle maximale Lautstärke des Kanals in dB.
KANAL
Aktuelle Kanalnummer, beginnend bei 0.
t Wenn eingestellt, werden Kanalnamen angezeigt. Standard ist aktiviert.
Showwaves
Wandeln Sie Eingangsaudio in einen Videoausgang um, der die Sample-Wellen darstellt.
Der Filter akzeptiert die folgenden Optionen:
Größe, s
Geben Sie die Videogröße für die Ausgabe an. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell. Der Standardwert ist "600x240".
Modus
Anzeigemodus einstellen.
Verfügbare Werte sind:
Punkt
Zeichne für jede Probe einen Punkt.
Linie
Zeichnen Sie für jede Probe eine vertikale Linie.
p2p Zeichne für jede Probe einen Punkt und eine Linie dazwischen.
Cline
Zeichnen Sie für jede Probe eine zentrierte vertikale Linie.
Der Standardwert ist "Punkt".
n Stellen Sie die Anzahl der Proben ein, die auf derselben Spalte gedruckt werden. Ein größerer Wert wird
die Framerate verringern. Muss eine positive ganze Zahl sein. Diese Option kann nur eingestellt werden, wenn
der Wert für Rate ist nicht explizit angegeben.
Bewertung, r
Stellen Sie die (ungefähre) Ausgabe-Bildrate ein. Dies geschieht durch Setzen der Option n. Standard
Wert ist "25".
split_channels
Legen Sie fest, ob Kanäle separat oder überlappend gezeichnet werden sollen. Der Standardwert ist 0.
Beispiele
· Geben Sie das Audio der Eingabedatei und die entsprechende Videodarstellung gleichzeitig aus
Zeit:
amovie=a.mp3,asplit[out0],showwaves[out1]
· Erstellen Sie ein synthetisches Signal und zeigen Sie es mit Showwaves an, wodurch eine Bildrate von 30 . erzwungen wird
Bilder pro Sekunde:
aevalsrc=sin(1*2*PI*t)*sin(880*2*PI*t):cos(2*PI*200*t),asplit[out0],showwaves=r=30[out1]
showwavespic
Wandeln Sie Eingangsaudio in einen einzelnen Videoframe um, der die Sample-Wellen repräsentiert.
Der Filter akzeptiert die folgenden Optionen:
Größe, s
Geben Sie die Videogröße für die Ausgabe an. Die Syntax dieser Option finden Sie im "Video
Größe" Abschnitt in ffmpeg-utils manuell. Der Standardwert ist "600x240".
split_channels
Legen Sie fest, ob Kanäle separat oder überlappend gezeichnet werden sollen. Der Standardwert ist 0.
Beispiele
· Extrahieren Sie eine Kanal-Split-Darstellung der Wellenform einer ganzen Audiospur in a
1024x800 Bild mit ffmpeg:
ffmpeg -i audio.flac -lavfi showwavespic=split_channels=1:s=1024x800 wave.png
Teilt, eine Teilung
Teilen Sie die Eingabe in mehrere identische Ausgaben auf.
"asplit" funktioniert mit Audioeingang, "split" mit Video.
Der Filter akzeptiert einen einzelnen Parameter, der die Anzahl der Ausgänge angibt. Wenn
nicht angegeben, standardmäßig auf 2.
Beispiele
· Erstellen Sie zwei separate Ausgaben aus derselben Eingabe:
[in] aufteilen [out0][out1]
· Um 3 oder mehr Ausgänge zu erstellen, müssen Sie die Anzahl der Ausgänge angeben, wie in:
[in] asplit=3 [out0][out1][out2]
· Erstellen Sie zwei separate Ausgaben aus derselben Eingabe, eine beschnittene und eine aufgefüllte:
[in] teilen [splitout1][splitout2];
[splitout1] crop=100:100:0:0 [cropout];
[splitout2] pad=200:200:100:100 [padout];
· Erstellen Sie 5 Kopien des Eingangsaudios mit ffmpeg:
ffmpeg -i EINGANG -filter_complex asplit=5 AUSGANG
zmq, azmq
Empfangen Sie Befehle, die über einen libzmq-Client gesendet werden, und leiten Sie sie an Filter im weiter
Filtergraph.
"zmq" und "azmq" arbeiten als Pass-Through-Filter. "zmq" muss zwischen zwei Videos eingefügt werden
Filter, "azmq" zwischen zwei Audiofiltern.
Um diese Filter zu aktivieren, müssen Sie die libzmq-Bibliothek und -Header installieren und konfigurieren
FFmpeg mit "--enable-libzmq".
Weitere Informationen zu libzmq finden Sie unter:http://www.zeromq.org/>
Die Filter "zmq" und "azmq" arbeiten als libzmq-Server, der die gesendeten Nachrichten empfängt
eine Netzwerkschnittstelle definiert durch die bind_adresse .
Die empfangene Nachricht muss folgendes Format haben:
[ ]
TARGET gibt das Ziel des Befehls an, normalerweise den Namen der Filterklasse oder a
spezifischer Name der Filterinstanz.
COMMAND gibt den Namen des Befehls für den Zielfilter an.
ARG ist optional und spezifiziert die optionale Argumentliste für das angegebene COMMAND.
Nach dem Empfang wird die Nachricht verarbeitet und der entsprechende Befehl wird in eingefügt
der Filtergraph. Abhängig vom Ergebnis sendet der Filter eine Antwort an den Client,
das Format annehmen:
NACHRICHT es ist optional.
Beispiele
Ansehen Tools/zmqsend für ein Beispiel für einen zmq-Client, der zum Senden von Befehlen verwendet werden kann
von diesen Filtern verarbeitet.
Betrachten Sie den folgenden Filtergraph, der von . erzeugt wurde ffplay
ffplay -dumpgraph 1 -f lavfi "
Farbe=s=100x100:c=rot [l];
Farbe=s=100x100:c=blau [r];
nullsrc=s=200x100, zmq [bg];
[bg][l] Überlagerung [bg+l];
[bg+l][r] Overlay=x=100 "
Um die Farbe der linken Seite des Videos zu ändern, kann der folgende Befehl verwendet werden:
echo Parsed_color_0 c gelb | tools/zmqsend
So ändern Sie die rechte Seite:
echo Parsed_color_1 c rosa | tools/zmqsend
MULTIMEDIA QUELLEN
Nachfolgend finden Sie eine Beschreibung der derzeit verfügbaren Multimediaquellen.
ein Film
Dies ist das gleiche wie Film Quelle, außer dass standardmäßig ein Audiostream ausgewählt wird.
Film
Lesen Sie Audio- und/oder Videostreams aus einem Filmcontainer.
Es akzeptiert die folgenden Parameter:
Dateinamen
Der Name der zu lesenden Ressource (nicht unbedingt eine Datei; er kann auch ein Gerät oder ein
Stream, auf den über ein Protokoll zugegriffen wird).
Formatname, f
Gibt das Format an, das für das Lesen des Films angenommen wird, und kann entweder der Name eines
Behälter oder ein Eingabegerät. Wenn nicht angegeben, wird das Format erraten von Filmname
oder durch Sondieren.
Suchpunkt, sp
Gibt den Suchpunkt in Sekunden an. Die Frames werden ab dieser Suche ausgegeben
Punkt. Der Parameter wird mit "av_strtod" ausgewertet, der Zahlenwert kann also sein
mit einem IS-Postfix angehängt. Der Standardwert ist "0".
Ströme, s
Gibt die zu lesenden Streams an. Es können mehrere Streams angegeben werden, getrennt durch "+". Der
source hat dann ebenso viele Ausgänge in der gleichen Reihenfolge. Die Syntax wird erklärt in
den Abschnitt ``Stream specifiers'' im ffmpeg-Handbuch. Zwei besondere Namen, "dv" und
"da" gibt den standardmäßigen (am besten geeigneten) Video- und Audiostream an. Standard ist
"dv" oder "da", wenn der Filter als "Amovie" bezeichnet wird.
stream_index, si
Gibt den Index des zu lesenden Videostreams an. Wenn der Wert -1 ist, ist der am besten geeignete
Videostream wird automatisch ausgewählt. Der Standardwert ist "-1". Veraltet. Wenn
Der Filter heißt "Film", er wählt Audio anstelle von Video aus.
Schleife
Gibt an, wie oft der Stream nacheinander gelesen werden soll. Wenn der Wert kleiner als 1 ist
der Stream wird immer wieder gelesen. Der Standardwert ist "1".
Beachten Sie, dass beim Loopen des Films die Quellzeitstempel nicht geändert werden
erzeugen nicht monoton ansteigende Zeitstempel.
Es ermöglicht das Überlagern eines zweiten Videos über den Haupteingang eines Filtergraphen, wie in gezeigt
diese Grafik:
Eingabe -----------> Deltapts0 --> Überlagerung --> Ausgabe
^
|
Film --> Maßstab --> Deltapts1 -------+
Beispiele
· Überspringen Sie 3.2 Sekunden ab dem Anfang der AVI-Datei in.avi und legen Sie sie über das
Eingang mit der Bezeichnung "in":
movie=in.avi:seek_point=3.2, scale=180:-1, setpts=PTS-STARTPTS [über];
[in] setpts=PTS-STARTPTS [Haupt];
[main][over] overlay=16:16 [aus]
· Von einem video4linux2-Gerät lesen und über den Eingang mit der Bezeichnung "in" legen:
movie=/dev/video0:f=video4linux2, scale=180:-1, setpts=PTS-STARTPTS [über];
[in] setpts=PTS-STARTPTS [Haupt];
[main][over] overlay=16:16 [aus]
· Lesen Sie den ersten Videostream und den Audiostream mit der ID 0x81 von dvd.vob; das Video
ist mit dem Pad mit dem Namen "Video" verbunden und das Audio ist mit dem Pad mit dem Namen verbunden
"Audio":
Film=dvd.vob:s=v:0+#0x81 [Video] [Audio]
Verwenden Sie ffmpeg-all online über die Dienste von onworks.net