Skip to content
Snippets Groups Projects
ffmpeg-doc.texi 59.6 KiB
Newer Older
\input texinfo @c -*- texinfo -*-

@settitle FFmpeg Documentation
@titlepage
@sp 7
@center @titlefont{FFmpeg Documentation}
@sp 3
@end titlepage


@chapter Introduction

FFmpeg is a very fast video and audio converter. It can also grab from
a live audio/video source.
The command line interface is designed to be intuitive, in the sense
Diego Biurrun's avatar
Diego Biurrun committed
that FFmpeg tries to figure out all parameters that can possibly be
derived automatically. You usually only have to specify the target
bitrate you want.

FFmpeg can also convert from any sample rate to any other, and resize
video on the fly with a high quality polyphase filter.

@chapter Quick Start

@section Video and Audio grabbing

FFmpeg can grab video and audio from devices given that you specify the input
format and device.
ffmpeg -f audio_device -i /dev/dsp -f video4linux2 -i /dev/video0 /tmp/out.mpg
Note that you must activate the right video source and channel before
Diego Biurrun's avatar
Diego Biurrun committed
launching FFmpeg with any TV viewer such as xawtv
(@url{http://bytesex.org/xawtv/}) by Gerd Knorr. You also
have to set the audio recording levels correctly with a
@section X11 grabbing

Diego Biurrun's avatar
Diego Biurrun committed
FFmpeg can grab the X11 display.
ffmpeg -f x11grab -s cif -i :0.0 /tmp/out.mpg
Diego Biurrun's avatar
Diego Biurrun committed
0.0 is display.screen number of your X11 server, same as
the DISPLAY environment variable.
ffmpeg -f x11grab -s cif -i :0.0+10,20 /tmp/out.mpg
@end example

0.0 is display.screen number of your X11 server, same as the DISPLAY environment
variable. 10 is the x-offset and 20 the y-offset for the grabbing.

@section Video and Audio file format conversion
Diego Biurrun's avatar
Diego Biurrun committed
* FFmpeg can use any supported file format and protocol as input:
Diego Biurrun's avatar
Diego Biurrun committed
* You can use YUV files as input:
ffmpeg -i /tmp/test%d.Y /tmp/out.mpg
It will use the files:
/tmp/test0.Y, /tmp/test0.U, /tmp/test0.V,
/tmp/test1.Y, /tmp/test1.U, /tmp/test1.V, etc...
The Y files use twice the resolution of the U and V files. They are
raw files, without header. They can be generated by all decent video
decoders. You must specify the size of the image with the @option{-s} option
Diego Biurrun's avatar
Diego Biurrun committed
if FFmpeg cannot guess it.
Diego Biurrun's avatar
Diego Biurrun committed
* You can input from a raw YUV420P file:
Diego Biurrun's avatar
Diego Biurrun committed
test.yuv is a file containing raw YUV planar data. Each frame is composed
of the Y plane followed by the U and V planes at half vertical and
Diego Biurrun's avatar
Diego Biurrun committed
* You can output to a raw YUV420P file:
ffmpeg -i mydivx.avi hugefile.yuv
@end example

* You can set several input files and output files:

@example
ffmpeg -i /tmp/a.wav -s 640x480 -i /tmp/a.yuv /tmp/a.mpg
Diego Biurrun's avatar
Diego Biurrun committed
Converts the audio file a.wav and the raw YUV video file a.yuv
to MPEG file a.mpg.
* You can also do audio and video conversions at the same time:
Diego Biurrun's avatar
Diego Biurrun committed
Converts a.wav to MPEG audio at 22050Hz sample rate.

* You can encode to several formats at the same time and define a
ffmpeg -i /tmp/a.wav -ab 64k /tmp/a.mp2 -ab 128k /tmp/b.mp2 -map 0:0 -map 0:0
Diego Biurrun's avatar
Diego Biurrun committed
Converts a.wav to a.mp2 at 64 kbits and to b.mp2 at 128 kbits. '-map
file:index' specifies which input stream is used for each output
stream, in the order of the definition of output streams.

* You can transcode decrypted VOBs

@example
ffmpeg -i snatch_1.vob -f avi -vcodec mpeg4 -b 800k -g 300 -bf 2 -acodec mp3 -ab 128k snatch.avi
Diego Biurrun's avatar
Diego Biurrun committed
This is a typical DVD ripping example; the input is a VOB file, the
output an AVI file with MPEG-4 video and MP3 audio. Note that in this
command we use B-frames so the MPEG-4 stream is DivX5 compatible, and
GOP size is 300 which means one intra frame every 10 seconds for 29.97fps
input video. Furthermore, the audio stream is MP3-encoded so you need
to enable LAME support by passing @code{--enable-mp3lame} to configure.
The mapping is particularly useful for DVD transcoding
Diego Biurrun's avatar
Diego Biurrun committed
NOTE: To see the supported input formats, use @code{ffmpeg -formats}.
Michael Niedermayer's avatar
Michael Niedermayer committed
ffmpeg [[infile options][@option{-i} @var{infile}]]... @{[outfile options] @var{outfile}@}...
@c man begin DESCRIPTION
As a general rule, options are applied to the next specified
file. Therefore, order is important, and you can have the same
Diego Biurrun's avatar
Diego Biurrun committed
option on the command line multiple times. Each occurrence is
then applied to the next input or output file.

Diego Biurrun's avatar
Diego Biurrun committed
* To set the video bitrate of the output file to 64kbit/s:
@example
ffmpeg -i input.avi -b 64k output.avi
@end example

* To force the frame rate of the input and output file to 24 fps:
@example
ffmpeg -r 24 -i input.avi output.avi
@end example

* To force the frame rate of the output file to 24 fps:
@example
ffmpeg -i input.avi -r 24 output.avi
@end example

* To force the frame rate of input file to 1 fps and the output file to 24 fps:
@example
ffmpeg -r 1 -i input.avi -r 24 output.avi
@end example

The format option may be needed for raw input files.
Diego Biurrun's avatar
Diego Biurrun committed
By default, FFmpeg tries to convert as losslessly as possible: It
uses the same audio and video parameters for the outputs as the one
Diego Biurrun's avatar
Diego Biurrun committed
Show license.
Fabrice Bellard's avatar
Fabrice Bellard committed

Diego Biurrun's avatar
Diego Biurrun committed
Show help.
Fabrice Bellard's avatar
Fabrice Bellard committed

@item -version
Show version.
Diego Biurrun's avatar
Diego Biurrun committed
Show available formats, codecs, protocols, ...
Fabrice Bellard's avatar
Fabrice Bellard committed

Diego Biurrun's avatar
Diego Biurrun committed
Force format.
Fabrice Bellard's avatar
Fabrice Bellard committed

@item -i filename
Diego Biurrun's avatar
Diego Biurrun committed
input filename
Diego Biurrun's avatar
Diego Biurrun committed
Overwrite output files.
@item -t duration
Diego Biurrun's avatar
Diego Biurrun committed
Set the recording time in seconds.
@code{hh:mm:ss[.xxx]} syntax is also supported.
@item -fs limit_size
Set the file size limit.

Diego Biurrun's avatar
Diego Biurrun committed
Seek to given time position in seconds.
@code{hh:mm:ss[.xxx]} syntax is also supported.
@item -itsoffset offset
Set the input time offset in seconds.
@code{[-]hh:mm:ss[.xxx]} syntax is also supported.
This option affects all the input files that follow it.
The offset is added to the timestamps of the input files.
Specifying a positive offset means that the corresponding
streams are delayed by 'offset' seconds.

@item -title string
Diego Biurrun's avatar
Diego Biurrun committed
Set the title.
@item -timestamp time
Set the timestamp.

@item -author string
Diego Biurrun's avatar
Diego Biurrun committed
Set the author.
@item -copyright string
Diego Biurrun's avatar
Diego Biurrun committed
Set the copyright.
@item -comment string
Diego Biurrun's avatar
Diego Biurrun committed
Set the comment.
@item -album string
Set the album.

@item -track number
Set the track.

@item -year number
Set the year.

@item -v verbose
Control amount of logging.

Fabrice Bellard's avatar
Fabrice Bellard committed
@item -target type
Specify target file type ("vcd", "svcd", "dvd", "dv", "dv50", "pal-vcd",
Diego Biurrun's avatar
Diego Biurrun committed
"ntsc-svcd", ... ). All the format options (bitrate, codecs,
buffer sizes) are then set automatically. You can just type:
Fabrice Bellard's avatar
Fabrice Bellard committed

@example
ffmpeg -i myfile.avi -target vcd /tmp/vcd.mpg
@end example

Diego Biurrun's avatar
Diego Biurrun committed
Nevertheless you can specify additional options as long as you know
they do not conflict with the standard, as in:

@example
ffmpeg -i myfile.avi -target vcd -bf 2 /tmp/vcd.mpg
@end example

@item -dframes number
Set the number of data frames to record.

@item -scodec codec
Force subtitle codec ('copy' to copy stream).

@item -newsubtitle
Add a new subtitle stream to the current output stream.

@item -slang code
Set the ISO 639 language code (3 letters) of the current subtitle stream.
Set the video bitrate in bit/s (default = 200 kb/s).
@item -vframes number
Set the number of video frames to record.
Set frame rate (Hz value, fraction or abbreviation), (default = 25).
Set frame size. The format is @samp{wxh} (ffserver default = 160x128, ffmpeg default = same as source).
Diego Biurrun's avatar
Diego Biurrun committed
The following abbreviations are recognized:
Fabrice Bellard's avatar
Fabrice Bellard committed
@table @samp
Fabrice Bellard's avatar
Fabrice Bellard committed
@item sqcif
128x96
@item qcif
176x144
@item cif
352x288
@item 4cif
704x576
Benoit Fouet's avatar
Benoit Fouet committed
@item qqvga
160x120
@item qvga
320x240
@item vga
640x480
@item svga
800x600
@item xga
1024x768
@item uxga
1600x1200
@item qxga
2048x1536
@item sxga
1280x1024
@item qsxga
2560x2048
@item hsxga
5120x4096
@item wvga
852x480
@item wxga
1366x768
@item wsxga
1600x1024
@item wuxga
1920x1200
@item woxga
2560x1600
@item wqsxga
3200x2048
@item wquxga
3840x2400
@item whsxga
6400x4096
@item whuxga
7680x4800
@item cga
320x200
@item ega
640x350
@item hd480
852x480
@item hd720
1280x720
@item hd1080
1920x1080
Fabrice Bellard's avatar
Fabrice Bellard committed
@end table

@item -aspect aspect
Diego Biurrun's avatar
Diego Biurrun committed
Set aspect ratio (4:3, 16:9 or 1.3333, 1.7777).
Fabrice Bellard's avatar
Fabrice Bellard committed
@item -croptop size
Diego Biurrun's avatar
Loading
Loading full blame...