1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-10 08:59:45 +00:00
mpv/DOCS/man/en/encode.rst
Rudolf Polzer 683966241c encode: remove dependency on current ffmpeg
Apparently, libav doesn't have the change for the new way to create a
libavformat context merged yet. So, we can't use that...

Rather, this commit fixes format specific avoptions another way.

On the downside, invalid format options are now detected very late, and
any attempt to set an option value to +something or -something will
append to the previously set option value (this logic can no longer be
specific to options of bitflag type, as finding out the option type is
what we simply cannot do with this interface).
2012-10-01 11:04:48 +02:00

143 lines
5.0 KiB
ReStructuredText

.. _encode:
ENCODING
========
You can encode files from one format/codec to another using this facility.
-o <filename>
Enables encoding mode and specifies the output file name.
--of=<format>
Specifies the output format (overrides autodetection by the extension of
the file specified by -o). This can be a comma separated list of possible
formats to try. See --of=help for a full list of supported formats.
--ofopts=<options>
Specifies the output format options for libavformat.
See --ofopts=help for a full list of supported options.
Options are managed in lists. There are a few commands to manage the
options list.
--ofopts-add=<options1[,options2,...]>
Appends the options given as arguments to the options list.
--ofopts-pre=<options1[,options2,...]>
Prepends the options given as arguments to the options list.
--ofopts-del=<index1[,index2,...]>
Deletes the options at the given indexes. Index numbers start at 0,
negative numbers address the end of the list (-1 is the last).
--ofopts-clr
Completely empties the options list.
--ofps=<float value>
Specifies the output format time base (default: 24000). Low values like 25
limit video fps by dropping frames.
--oautofps
Sets the output format time base to the guessed frame rate of the input
video (simulates mencoder behaviour, useful for AVI; may cause frame
drops). Note that not all codecs and not all formats support VFR
encoding, and some which do have bugs when a target bitrate is
specified - use --ofps or --oautofps to force CFR encoding in these
cases.
--oharddup
If set, the frame rate given by --ofps is attained not by skipping time
codes, but by duplicating frames (constant frame rate mode).
--oneverdrop
If set, frames are never dropped. Instead, time codes of video are
readjusted to always increase. This may cause AV desync, though; to
work around this, use a high-fps time base using --ofps and absolutely
avoid --oautofps.
--oac=<codec>
Specifies the output audio codec. This can be a comma separated list of
possible codecs to try. See --oac=help for a full list of supported codecs.
--oaoffset=<value>
Shifts audio data by the given time (in seconds) by adding/removing
samples at the start.
--oacopts=<options>
Specifies the output audio codec options for libavcodec.
See --oacopts=help for a full list of supported options.
EXAMPLE: "--oac=libmp3lame --oacopts=b=128000" selects 128kbps MP3
encoding.
Options are managed in lists. There are a few commands to manage the
options list.
--oacopts-add=<options1[,options2,...]>
Appends the options given as arguments to the options list.
--oacopts-pre=<options1[,options2,...]>
Prepends the options given as arguments to the options list.
--oacopts-del=<index1[,index2,...]>
Deletes the options at the given indexes. Index numbers start at 0,
negative numbers address the end of the list (-1 is the last).
--oacopts-clr
Completely empties the options list.
--oafirst
Force the audio stream to become the first stream in the output. By default
the order is unspecified.
--ovc=<codec>
Specifies the output video codec. This can be a comma separated list of
possible codecs to try. See --ovc=help for a full list of supported codecs.
--ovoffset=<value>
Shifts video data by the given time (in seconds) by shifting the pts
values.
--ovcopts <options>
Specifies the output video codec options for libavcodec.
See --ovcopts=help for a full list of supported options.
EXAMPLE: "--ovc=mpeg4 --oacopts=qscale=5" selects constant quantizer scale
5 for MPEG-4 encoding.
EXAMPLE: "--ovc=libx264 --ovcopts=crf=23" selects VBR quality factor 23 for
H.264 encoding.
Options are managed in lists. There are a few commands to manage the
options list.
--ovcopts-add=<options1[,options2,...]>
Appends the options given as arguments to the options list.
--ovcopts-pre=<options1[,options2,...]>
Prepends the options given as arguments to the options list.
--ovcopts-del=<index1[,index2,...]>
Deletes the options at the given indexes. Index numbers start at 0,
negative numbers address the end of the list (-1 is the last).
--ovcopts-clr
Completely empties the options list.
--ovfirst
Force the video stream to become the first stream in the output. By default
the order is unspecified.
--ocopyts
Copies input pts to the output video (not supported by some output
container formats, e.g. avi). Discontinuities are still fixed.
By default, audio pts are set to playback time and video pts are
synchronized to match audio pts, as some output formats do not support
anything else.
--orawts
Copies input pts to the output video (not supported by some output
container formats, e.g. avi). In this modem discontinuities are not fixed
and all pts are passed through as-is. Never seek backwards or use multiple
input files in this mode!