Commit 289a8e4d authored by Piero Bugoni's avatar Piero Bugoni Committed by Diego Biurrun

Add watermark and drawtext descriptions, plus some random fixes.

patch by Piero Bugoni, crboca32 yahoo com

Originally committed as revision 8281 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 20e708cb
...@@ -17,8 +17,8 @@ the video to be modified or examined between the decoder and the encoder. ...@@ -17,8 +17,8 @@ the video to be modified or examined between the decoder and the encoder.
Any number of hook modules can be placed inline, and they are run in the Any number of hook modules can be placed inline, and they are run in the
order that they were specified on the ffmpeg command line. order that they were specified on the ffmpeg command line.
A few modules are provided and are described below. They are all intended to The video hook modules are provided for use as a base for your own modules,
be used as a base for your own modules. and are described below.
Modules are loaded using the -vhook option to ffmpeg. The value of this parameter Modules are loaded using the -vhook option to ffmpeg. The value of this parameter
is a space separated list of arguments. The first is the module name, and the rest is a space separated list of arguments. The first is the module name, and the rest
...@@ -48,7 +48,7 @@ colors than would an RGB cuboid. ...@@ -48,7 +48,7 @@ colors than would an RGB cuboid.
This module implements a text overlay for a video image. Currently it This module implements a text overlay for a video image. Currently it
supports a fixed overlay or reading the text from a file. The string supports a fixed overlay or reading the text from a file. The string
is passed through strftime so that it is easy to imprint the date and is passed through strftime() so that it is easy to imprint the date and
time onto the image. time onto the image.
This module depends on the external library imlib2, available on This module depends on the external library imlib2, available on
...@@ -59,7 +59,13 @@ You may also overlay an image (even semi-transparent) like TV stations do. ...@@ -59,7 +59,13 @@ You may also overlay an image (even semi-transparent) like TV stations do.
You may move either the text or the image around your video to create You may move either the text or the image around your video to create
scrolling credits, for example. scrolling credits, for example.
Text fonts are being looked for in a FONTPATH environment variable. The font file used is looked for in a FONTPATH environment variable, and
prepended to the point size as a command line option and can be specified
with the full path to the font file, as in:
@example
-F /usr/X11R6/lib/X11/fonts/TTF/VeraBd.ttf/20
@end example
where 20 is the point size.
Options: Options:
@multitable @columnfractions .2 .8 @multitable @columnfractions .2 .8
...@@ -67,8 +73,8 @@ Options: ...@@ -67,8 +73,8 @@ Options:
@item @option{-F <fontname>} @tab The font face and size @item @option{-F <fontname>} @tab The font face and size
@item @option{-t <text>} @tab The text @item @option{-t <text>} @tab The text
@item @option{-f <filename>} @tab The filename to read text from @item @option{-f <filename>} @tab The filename to read text from
@item @option{-x <expresion>} @tab X coordinate of text or image @item @option{-x <expresion>} @tab x coordinate of text or image
@item @option{-y <expresion>} @tab Y coordinate of text or image @item @option{-y <expresion>} @tab y coordinate of text or image
@item @option{-i <filename>} @tab The filename to read a image from @item @option{-i <filename>} @tab The filename to read a image from
@end multitable @end multitable
...@@ -105,13 +111,53 @@ Usage examples: ...@@ -105,13 +111,53 @@ Usage examples:
ffmpeg -i input.avi -vhook \ ffmpeg -i input.avi -vhook \
'vhook/imlib2.dll -c red -F Vera.ttf/20 -x 150+0.5*N -y 70+0.25*N -t Hello' \ 'vhook/imlib2.dll -c red -F Vera.ttf/20 -x 150+0.5*N -y 70+0.25*N -t Hello' \
-acodec copy -sameq output.avi -acodec copy -sameq output.avi
# Date and time stamp, security-camera style:
ffmpeg -r 29.97 -s 320x256 -f video4linux -i /dev/video0 \
-vhook 'vhook/imlib2.so -x 0 -y 0 -i black-260x20.png' \
-vhook 'vhook/imlib2.so -c white -F VeraBd.ttf/12 -x 0 -y 0 -t %A-%D-%T' \
output.avi
In this example the video is captured from the first video capture card as a
320x256 AVI, and a black 260 by 20 pixel PNG image is placed in the upper
left corner, with the day, date and time overlaid on it in Vera Bold 12
point font. A simple black PNG file 260 pixels wide and 20 pixels tall
was created in the GIMP for this purpose.
# Scrolling credits from a text file
ffmpeg -i input.avi -vhook \
'vhook/imlib2.so -c white -F VeraBd.ttf/16 -x 100 -y -1.0*N -f credits.txt' \
-sameq output.avi
In this example, the text is stored in a file, and is positioned 100
pixels from the left hand edge of the video. The text is scrolled from the
bottom up. Making the y factor positive will scroll from the top down.
Increasing the magnitude of the y factor makes the text scroll faster,
decreasing it makes it scroll slower. Hint: Blank lines containing only
a newline are treated as end-of-file. To create blank lines, use lines
that consist of space characters only.
# scrolling credits from a graphics file
ffmpeg -sameq -i input.avi \
-vhook 'vhook/imlib2.so -x 0 -y -1.0*N -i credits.png' output.avi
In this example, a transparent PNG file the same width as the video
(e.g. 320 pixels), but very long, (e.g. 3000 pixels), was created, and
text, graphics, brushstrokes, etc, were added to the image. The image
is then scrolled up, from the bottom of the frame.
@end example @end example
@section ppm.c @section ppm.c
It's basically a launch point for a PPM pipe, so you can use any It's basically a launch point for a PPM pipe, so you can use any
executable (or script) which consumes a PPM on stdin and produces a PPM executable (or script) which consumes a PPM on stdin and produces a PPM
on stdout (and flushes each frame). on stdout (and flushes each frame). The Netpbm utilities are a series of
such programs.
A list of them is here:
@url{http://netpbm.sourceforge.net/doc/directory.html}
Usage example: Usage example:
...@@ -119,4 +165,96 @@ Usage example: ...@@ -119,4 +165,96 @@ Usage example:
ffmpeg -i input -vhook "/path/to/ppm.so some-ppm-filter args" output ffmpeg -i input -vhook "/path/to/ppm.so some-ppm-filter args" output
@end example @end example
@section drawtext.c
This module implements a text overlay for a video image. Currently it
supports a fixed overlay or reading the text from a file. The string
is passed through strftime() so that it is easy to imprint the date and
time onto the image.
Features:
@itemize @minus
@item TrueType, Type1 and others via the FreeType2 library
@item Font kerning (better output)
@item Line Wrap (put the text that doesn't fit one line on the next line)
@item Background box (currently in development)
@item Outline
@end itemize
Options:
@multitable @columnfractions .2 .8
@item @option{-c <color>} @tab Foreground color of the text ('internet' way) <#RRGGBB> [default #FFFFFF]
@item @option{-C <color>} @tab Background color of the text ('internet' way) <#RRGGBB> [default #000000]
@item @option{-f <font-filename>} @tab font file to use
@item @option{-t <text>} @tab text to display
@item @option{-T <filename>} @tab file to read text from
@item @option{-x <pos>} @tab x coordinate of the start of the text
@item @option{-y <pos>} @tab y coordinate of the start of the text
@end multitable
Text fonts are being looked for in a FONTPATH environment variable.
If the FONTPATH environment variable is not available, or is not checked by
your target (i.e. Cygwin), then specify the full path to the font file as in:
@example
-f /usr/X11R6/lib/X11/fonts/TTF/VeraBd.ttf
@end example
Usage Example:
@example
# Remember to set the path to your fonts
FONTPATH="/cygdrive/c/WINDOWS/Fonts/"
FONTPATH="$FONTPATH:/usr/share/imlib2/data/fonts/"
FONTPATH="$FONTPATH:/usr/X11R6/lib/X11/fonts/TTF/"
export FONTPATH
# Time and date display
ffmpeg -f video4linux2 -i /dev/video0 \
-vhook 'vhook/drawtext.so -f VeraBd.ttf -t %A-%D-%T' movie.mpg
This example grabs video from the first capture card and outputs it to an
MPEG video, and places "Weekday-dd/mm/yy-hh:mm:ss" at the top left of the
frame, updated every second, using the Vera Bold TrueType Font, which
should exist in: /usr/X11R6/lib/X11/fonts/TTF/
@end example
Check the man page for strftime() for all the various ways you can format
the date and time.
@section watermark.c
Command Line options:
@multitable @columnfractions .2 .8
@item @option{-m [0|1]} @tab Mode (default: 0, see below)
@item @option{-t 000000 - FFFFFF} @tab Threshold, six digit hex number
@item @option{-f <filename>} @tab Watermark image filename, must be specified!
@end multitable
MODE 0:
The watermark picture works like this (assuming color intensities 0..0xFF):
Per color do this:
If mask color is 0x80, no change to the original frame.
If mask color is < 0x80 the absolute difference is subtracted from the
frame. If result < 0, result = 0.
If mask color is > 0x80 the absolute difference is added to the
frame. If result > 0xFF, result = 0xFF.
You can override the 0x80 level with the -t flag. E.g. if threshold is
000000 the color value of watermark is added to the destination.
This way a mask that is visible both in light and dark pictures can be made
(e.g. by using a picture generated by the Gimp and the bump map tool).
An example watermark file is at:
@url{http://engene.se/ffmpeg_watermark.gif}
MODE 1:
Per color do this:
If mask color > threshold color then the watermark pixel is used.
Example usage:
@example
ffmpeg -i infile -vhook '/path/watermark.so -f wm.gif' -an out.mov
ffmpeg -i infile -vhook '/path/watermark.so -f wm.gif -m 1 -t 222222' -an out.mov
@end example
@bye @bye
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment