Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
3b266da3
Commit
3b266da3
authored
Apr 01, 2012
by
Anton Khirnov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avconv: add support for complex filtergraphs.
parent
560f7774
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
467 additions
and
57 deletions
+467
-57
avconv.c
avconv.c
+420
-56
avconv.texi
doc/avconv.texi
+46
-1
filters.texi
doc/filters.texi
+1
-0
No files found.
avconv.c
View file @
3b266da3
This diff is collapsed.
Click to expand it.
doc/avconv.texi
View file @
3b266da3
...
...
@@ -207,6 +207,9 @@ codec-dependent.
@var
{
filter
_
graph
}
is a description of the filter graph to apply to
the stream. Use @code
{
-filters
}
to show all the available filters
(including also sources and sinks).
See also the @option
{
-filter
_
complex
}
option if you want to create filter graphs
with multiple inputs and/or outputs.
@item -pre[:@var
{
stream
_
specifier
}
] @var
{
preset
_
name
}
(@emph
{
output,per-stream
}
)
Specify the preset for matching stream(s).
...
...
@@ -460,7 +463,7 @@ Synchronize read on input.
@section Advanced options
@table @option
@item -map [-]@var
{
input
_
file
_
id
}
[:@var
{
stream
_
specifier
}
][,@var
{
sync
_
file
_
id
}
[:@var
{
stream
_
specifier
}
]] (@emph
{
output
}
)
@item -map [-]@var
{
input
_
file
_
id
}
[:@var
{
stream
_
specifier
}
][,@var
{
sync
_
file
_
id
}
[:@var
{
stream
_
specifier
}
]]
| @var
{
[linklabel]
}
(@emph
{
output
}
)
Designate one or more input streams as a source for the output file. Each input
stream is identified by the input file index @var
{
input
_
file
_
id
}
and
...
...
@@ -476,6 +479,10 @@ the source for output stream 1, etc.
A @code
{
-
}
character before the stream identifier creates a "negative" mapping.
It disables matching streams from already created mappings.
An alternative @var
{
[linklabel]
}
form will map outputs from complex filter
graphs (see the @option
{
-filter
_
complex
}
option) to the output file.
@var
{
linklabel
}
must correspond to a defined output link label in the graph.
For example, to map ALL streams from the first input file to output
@example
avconv -i INPUT -map 0 output
...
...
@@ -639,6 +646,44 @@ Force a tag/fourcc for matching streams.
@item -cpuflags mask (@emph
{
global
}
)
Set a mask that's applied to autodetected CPU flags. This option is intended
for testing. Do not use it unless you know what you're doing.
@item -filter
_
complex @var
{
filtergraph
}
(@emph
{
global
}
)
Define a complex filter graph, i.e. one with arbitrary number of inputs and/or
outputs. For simple graphs -- those with one input and one output of the same
type -- see the @option
{
-filter
}
options. @var
{
filtergraph
}
is a description of
the filter graph, as described in @ref
{
Filtergraph syntax
}
.
Input link labels must refer to input streams using the
@code
{
[file
_
index:stream
_
specifier]
}
syntax (i.e. the same as @option
{
-map
}
uses). If @var
{
stream
_
specifier
}
matches multiple streams, the first one will be
used. An unlabeled input will be connected to the first unused input stream of
the matching type.
Output link labels are referred to with @option
{
-map
}
. Unlabeled outputs are
added to the first output file.
For example, to overlay an image over video
@example
avconv -i video.mkv -i image.png -filter
_
complex '[0:v][1:v]overlay[out]' -map
'[out]' out.mkv
@end example
Here @code
{
[0:v]
}
refers to the first video stream in the first input file,
which is linked to the first (main) input of the overlay filter. Similarly the
first video stream in the second input is linked to the second (overlay) input
of overlay.
Assuming there is only one video stream in each input file, we can omit input
labels, so the above is equivalent to
@example
avconv -i video.mkv -i image.png -filter
_
complex 'overlay[out]' -map
'[out]' out.mkv
@end example
Furthermore we can omit the output label and the single output from the filter
graph will be added to the output file automatically, so we can simply write
@example
avconv -i video.mkv -i image.png -filter
_
complex 'overlay' out.mkv
@end example
@end table
@c man end OPTIONS
...
...
doc/filters.texi
View file @
3b266da3
...
...
@@ -14,6 +14,7 @@ number of input and output pads of the filter.
A filter with no input pads is called a "source", a filter with no
output pads is called a "sink".
@anchor{Filtergraph syntax}
@section Filtergraph syntax
A filtergraph can be represented using a textual representation, which
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment