From: Stefano Sabatini <stefasab@gmail.com>
To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org>
Cc: Stefano Sabatini <stefasab@gmail.com>
Subject: [FFmpeg-devel] [PATCH] doc/filters: extend section about command, warn about undesirable behaviors
Date: Mon, 27 Mar 2023 02:08:41 +0200
Message-ID: <20230327000841.94338-1-stefasab@gmail.com> (raw)
Extend documentation about commands, and add a note to warn users in
case of commands which might fail in special cases, based on a report
by Michael Koch.
Fix trac issue:
http://trac.ffmpeg.org/ticket/8987
---
doc/filters.texi | 45 ++++++++++++++++++++++++++++++++++++++++-----
1 file changed, 40 insertions(+), 5 deletions(-)
diff --git a/doc/filters.texi b/doc/filters.texi
index 4449998ba4..3db7280bb5 100644
--- a/doc/filters.texi
+++ b/doc/filters.texi
@@ -327,11 +327,41 @@ See @code{ffmpeg -filters} to view which filters have timeline support.
@anchor{commands}
@chapter Changing options at runtime with a command
-Some options can be changed during the operation of the filter using
-a command. These options are marked 'T' on the output of
-@command{ffmpeg} @option{-h filter=<name of filter>}.
-The name of the command is the name of the option and the argument is
-the new value.
+Some filters accepts interactive commands which can be sent to filters to
+interactively change their behavior .
+
+When a filter supports commands, it is possible to send a command to the filter,
+either programmatically through the @code{avfilter_process_command()} function
+defined in @file{avfilter.h}, or through dedicated filters such as @ref{sendcmd}
+or @ref{zmq}.
+
+A command can be sent to a filtergraph by specifying the following parameters:
+@table @option
+
+@item target
+a filter target, is specified as the unique filter name in the filterchain, or
+as the filter class name followed by "@@@var{id}", where @var{id} is the unique
+filter identifier assigned to the filter in the filtergraph specification
+
+@item command
+the name of the command defined in the filter
+
+@item arg
+an optional argument specifying the option to set through the command
+@end table
+
+Commands are shown as options and marked with the @code{T} flag on the output of
+@command{ffmpeg} @option{-h filter=<name of filter>}. The name of the
+corresponding option is the name of the command and the argument is the value
+set through the command.
+
+Keep in mind that some commands might change some filters configuration causing
+unexpected behavior. For example, it is possible to send the @command{width}
+command to the @ref{scale} filter for changing the size of a video stream. But
+changing the size mid-stream is not supported by many other filters (for example
+@ref{eq}, @ref{colorkey} and @ref{despill}). In some cases it works (for example
+the output of @ref{scale} can be used as the second input of @ref{overlay}), but
+in most other cases it would fail.
@anchor{framesync}
@chapter Options for filters with several inputs (framesync)
@@ -9503,6 +9533,7 @@ Allowed range is from 0.0 to 1.0.
This filter supports the all above options as @ref{commands}.
+@anchor{colorkey}
@section colorkey
RGB colorspace color keying.
This filter operates on 8-bit RGB format frames by setting the alpha component of each pixel
@@ -11421,6 +11452,7 @@ specified file.
@end table
+@anchor{despill}
@section despill
Remove unwanted contamination of foreground colors, caused by reflected color of
@@ -12704,6 +12736,7 @@ Set the scaling dimension: @code{2} for @code{2xEPX}, @code{3} for
Default is @code{3}.
@end table
+@anchor{eq}
@section eq
Set brightness, contrast, saturation and approximate gamma adjustment.
@@ -29016,6 +29049,7 @@ ffmpeg -copyts -vsync 0 -segment_time_metadata 1 -i input.ffconcat -vf select=co
@end example
@end itemize
+@anchor{sendcmd}
@section sendcmd, asendcmd
Send commands to filters in the filtergraph.
@@ -30762,6 +30796,7 @@ ffmpeg -i INPUT -filter_complex asplit=5 OUTPUT
@end example
@end itemize
+@anchor{zmq}
@section zmq, azmq
Receive commands sent through a libzmq client, and forward them to
--
2.25.1
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next reply other threads:[~2023-03-27 0:08 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-03-27 0:08 Stefano Sabatini [this message]
2023-03-27 5:24 ` Gyan Doshi
2023-03-28 23:21 ` Stefano Sabatini
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230327000841.94338-1-stefasab@gmail.com \
--to=stefasab@gmail.com \
--cc=ffmpeg-devel@ffmpeg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
This inbox may be cloned and mirrored by anyone:
git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
ffmpegdev@gitmailbox.com
public-inbox-index ffmpegdev
Example config snippet for mirrors.
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git