Subtitle

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
(corrected default align parameters)
(arg list formatting; merge default list into main arg list; minor re-phrasing)
Line 3: Line 3:
 
The Subtitle filter adds anti-aliased text to a range of frames. All parameters after ''text'' are optional and can be omitted or specified out of order using the ''name=value'' syntax.
 
The Subtitle filter adds anti-aliased text to a range of frames. All parameters after ''text'' are optional and can be omitted or specified out of order using the ''name=value'' syntax.
  
===Parameters===
+
The short form (with all default parameters) is useful when you don't really care what the subtitle looks like as long as you can see it--for example, when you're using [[StackVertical]] and its ilk to display several versions of a frame at once, and you want to label them to remember which is which.
  
''text'' is the text which will be overlayed on the clip starting from frame ''first_frame'' and ending with frame ''last_frame''.  
+
This filter is used internally by AviSynth for [[Version]], [[ShowFrameNumber]] and for reporting error messages.
  
(''x'',''y'') is the position of the text. The parameters ''x'' and ''y'' can be set to -1 to automatically calculate and use the horizontal or vertical center coordinate. Other negative values of ''x'' and ''y'' can be used to give subtitles partially off the screen. '''Caution:''' If your script uses Subtitle with [[Animate]] and negative ''x'' or ''y'' values, ''x'' or ''y'' might momentarily become -1, causing a glitch in the video. Starting from v2.60 they can be float.
+
===Parameters===
  
''font'' is the font of the text (all installed fonts on the current machine are available, they are located in your 'windows\fonts' folder).
+
:;text
 +
:: The text to be displayed.  
  
''size'' is the height of the text in pixels, and is rounded to the nearest 0.125 pixel.
+
:;x, y
 +
:: Text position. Can be set to -1 to automatically center the text horizontally or vertically, respectively. Negative values of ''x'' and ''y'' not equal to -1 can be used to move subtitles partially off the screen.
  
The ''text_color'' and ''halo_color'' should be given as hexadecimal $aarrggbb values, similar to HTML--except that they start with $ instead of # and the 4th octet specifies the alpha transparency. $00rrggbb is completely opaque, $FF000000 is fully transparent. You can disable the halo by selecting this color. See [[Colors]] for more information on specifying colors.
+
:: Default values:
 +
::: x = 8 if align=1,4,7 or none; -1 if align=2,5,8; or width-8 if align=3,6,9
 +
::: y = ''size'' if align=4,5,6 or none; 0 if align=7,8,9; or height-1 if align=1,2,3
  
The ''align'' parameter allows you to set where the text is placed relative to the (x,y) location and is based on the numeric keypad as follows:
+
::'''Caution:''' If your script uses Subtitle with [[Animate]] and negative ''x'' or ''y'' values, ''x'' or ''y'' might momentarily become -1, causing a glitch in the video. Starting from v2.60 they can be float.
  
{| border="1"
+
:;first_frame, last_frame
|-
+
::The text will be shown starting from frame ''first_frame'' and ending with frame ''last_frame''.
| <left> 7 <top>
+
| <nowiki><center></nowiki> 8 <top>
+
| <right> 9 <top>
+
| top of text aligned to y-location for align=7,8,9
+
|-
+
| <left> 4 <baseline>
+
| <nowiki><center></nowiki> 5 <baseline>
+
| <right> 6 <baseline>
+
| baseline of text aligned to y-location for align=4,5,6
+
|-
+
| <left> 1 <bottom>
+
| <nowiki><center></nowiki> 2 <bottom>
+
| <right> 3 <bottom>
+
| bottom of text aligned to y-location for align=1,2,3
+
|-
+
| start at x for align=1,4,7
+
| center on x for align=2,5,8
+
| end at x for align=3,6,9
+
|
+
|}
+
  
Note: There is no Y-center alignment setting.
+
::Default values: first_frame=0, last_frame=Framecount(''clip'')-1
  
The ''spc'' parameter allows you to modify the character spacing (0=unchanged). The value can be positive or negative to widen or narrow the text. Per the Visual C++ documentation of the function SetTextCharacterExtra(), that performs this task, this value is in logical units and rounded to the nearest 0.125 pixel. This is helpful for trying to match typical fonts on the PC to fonts used in film and television credits which are usually wider for the same height or to just fit or fill in a space with a fixed per-character adjustment.
+
:;font
 +
::Font name; default "Arial".  
  
Multi-line text using "\n" is added in v2.57 and it is used if the lsp (line spacing) parameter is set. It sets the additional line space between two lines in 0.125 pixel units. (In the unlikely event that you want to output the characters "\n" literally in a multi-line text, you can do this by using "\\n".)
+
::All installed fonts on the current machine are available; they are located in your 'windows\fonts' folder.
  
The ''font_width'' parameter allows you to modify, in 0.125 units, the aspect ratio of character glyphs per the Visual C++ documentation of the function CreateFont(). It is related to the size parameter by the default GDI aspect ratio and the natural aspect ratio of the chosen font.
+
:;size
 +
::Height of the text in pixels, and is rounded to the nearest 0.125 pixel. Default 18.
  
The ''font_angle'' parameter allows you to modify the baseline angle of text in 0.1 degree increments anti-clockwise.
+
:;text_color, halo_color
 +
::Colors for font fill and outline respectively. Default yellow, black.  
  
The ''interlaced'' parameter when enabled reduces flicker from sharp fine vertical transitions on interlaced displays. It applies a mild vertical blur by increasing the window for the anti-aliaser to include 0.5 of the pixel weight from the lines above and below.
+
:::These may be any of the [[Preset colors]], or specified as hexadecimal $aarrggbb values, similar to HTML--except that they start with $ instead of # and the 4th octet specifies the alpha transparency. $00rrggbb is completely opaque, $FF000000 is fully transparent. You can disable the halo by selecting this color. See [[Colors]] for more information on specifying colors.
  
The short form (with all default parameters) is useful when you don't really care what the subtitle looks like as long as you can see it--for example, when you're using [[StackVertical]] and its ilk to display several versions of a frame at once, and you want to label them to remember which is which.
+
:;align
 
+
::Allows you to set where the text is placed relative to the (x,y) location and is based on the numeric keypad as follows:
This filter is used internally by AviSynth for the [[Version]] command and for reporting error messages, and the subtitling apparatus is also used by [[ShowFrameNumber]].
+
<div style="margin-left:8em"><div>
 
+
{| border="1" cellpadding="4" style="text-align:center;vertical-align:middle;"
===Default values===
+
|-
 
+
| 7
:''clip''
+
| 8
::: last
+
| 9
 
+
| style="text-align:left;" | ''top'' of text at y.
:''text''
+
|-
::: no default, must be specified
+
| 4
 
+
| 5
:''x''
+
| 6
::: 8 if align=1,4,7 or none; -1 if align=2,5,8; or width-8 if align=3,6,9
+
| style="text-align:left;" | ''baseline'' of text at y.
 
+
|-
:''y''
+
| 1
::: ''size'' if align=4,5,6 or none; 0 if align=7,8,9; or height-1 if align=1,2,3
+
| 2
 
+
| 3
:''first_frame''
+
| style="text-align:left;" | ''bottom'' of text at y.
::: 0
+
|-
 
+
| style="text-align:left;" | ''start'' at x.
:''last_frame''
+
| style="text-align:left;" | ''center'' on x.
::: framecount(''clip'')-1
+
| style="text-align:left;" | ''end'' at x.
 
+
|
:''font''
+
|}</div></div>
::: "Arial"
+
 
+
:''size''
+
::: 18.0
+
  
:''text_color''
+
::Default 7, or top-left. Note there is no Y-center alignment setting.
::: $00FFFF00 <full opaque yellow>
+
  
:''halo_color''
+
:;spc
::: 0 <full opaque black>
+
::Modify the character spacing; default 0. The value can be positive or negative to widen or narrow the text; 0=unchanged.
  
:''align''
+
:::Per the Visual C++ documentation of the function SetTextCharacterExtra(), that performs this task, this value is in logical units and rounded to the nearest 0.125 pixel. This is helpful for trying to match typical fonts on the PC to fonts used in film and television credits which are usually wider for the same height or to just fit or fill in a space with a fixed per-character adjustment.
::: Normally 7 <left and baseline>; if x=-1, then 2 <horizontal center and baseline>
+
  
:''spc''
+
:;lsp
::: 0 <font spacing unchanged>
+
::Line Spacing Parameter; enables '''multi-line text''' (where "\n" enters a line break) and sets the additional inter-line spacing (if any) in 0.125 pixel units. Multi-line text was added in v2.57. Default undefined, which disables multi-line text.
  
:''lsp''
+
::In the unlikely event that you want to output the characters "\n" literally in a multi-line text, you can do this by using "\\n".
::: <multiline is not enabled>
+
  
:''font_width''
+
:;font_width
::: 0 <system default>
+
::Allows you to modify, in 0.125 units, font character aspect ratio. Default=0.
  
:''font_angle''
+
:::For more information, see the Visual C++ documentation of the function CreateFont(). It is related to the size parameter by the default GDI aspect ratio and the natural aspect ratio of the chosen font.
::: 0.0 degrees
+
  
:''interlaced''
+
:;font_angle
::: false
+
::Allows you to modify the baseline angle of text in 0.1 degree increments anti-clockwise. Default=0.
  
 +
:;interlaced
 +
::When enabled, reduces flicker from sharp fine vertical transitions on interlaced displays. It applies a mild vertical blur by increasing the anti-aliasing window to include 0.5 of the pixel weight from the lines above and below. Default=false.
  
 
===Examples===
 
===Examples===

Revision as of 13:47, 14 September 2014

Subtitle(clip clip, string text, float x, float y, int first_frame, int last_frame, string font, int size, int text_color, int halo_color, int align, int spc, int lsp, float font_width, float font_angle, bool interlaced)

The Subtitle filter adds anti-aliased text to a range of frames. All parameters after text are optional and can be omitted or specified out of order using the name=value syntax.

The short form (with all default parameters) is useful when you don't really care what the subtitle looks like as long as you can see it--for example, when you're using StackVertical and its ilk to display several versions of a frame at once, and you want to label them to remember which is which.

This filter is used internally by AviSynth for Version, ShowFrameNumber and for reporting error messages.

Contents

Parameters

text
The text to be displayed.
x, y
Text position. Can be set to -1 to automatically center the text horizontally or vertically, respectively. Negative values of x and y not equal to -1 can be used to move subtitles partially off the screen.
Default values:
x = 8 if align=1,4,7 or none; -1 if align=2,5,8; or width-8 if align=3,6,9
y = size if align=4,5,6 or none; 0 if align=7,8,9; or height-1 if align=1,2,3
Caution: If your script uses Subtitle with Animate and negative x or y values, x or y might momentarily become -1, causing a glitch in the video. Starting from v2.60 they can be float.
first_frame, last_frame
The text will be shown starting from frame first_frame and ending with frame last_frame.
Default values: first_frame=0, last_frame=Framecount(clip)-1
font
Font name; default "Arial".
All installed fonts on the current machine are available; they are located in your 'windows\fonts' folder.
size
Height of the text in pixels, and is rounded to the nearest 0.125 pixel. Default 18.
text_color, halo_color
Colors for font fill and outline respectively. Default yellow, black.
These may be any of the Preset colors, or specified as hexadecimal $aarrggbb values, similar to HTML--except that they start with $ instead of # and the 4th octet specifies the alpha transparency. $00rrggbb is completely opaque, $FF000000 is fully transparent. You can disable the halo by selecting this color. See Colors for more information on specifying colors.
align
Allows you to set where the text is placed relative to the (x,y) location and is based on the numeric keypad as follows:
7 8 9 top of text at y.
4 5 6 baseline of text at y.
1 2 3 bottom of text at y.
start at x. center on x. end at x.
Default 7, or top-left. Note there is no Y-center alignment setting.
spc
Modify the character spacing; default 0. The value can be positive or negative to widen or narrow the text; 0=unchanged.
Per the Visual C++ documentation of the function SetTextCharacterExtra(), that performs this task, this value is in logical units and rounded to the nearest 0.125 pixel. This is helpful for trying to match typical fonts on the PC to fonts used in film and television credits which are usually wider for the same height or to just fit or fill in a space with a fixed per-character adjustment.
lsp
Line Spacing Parameter; enables multi-line text (where "\n" enters a line break) and sets the additional inter-line spacing (if any) in 0.125 pixel units. Multi-line text was added in v2.57. Default undefined, which disables multi-line text.
In the unlikely event that you want to output the characters "\n" literally in a multi-line text, you can do this by using "\\n".
font_width
Allows you to modify, in 0.125 units, font character aspect ratio. Default=0.
For more information, see the Visual C++ documentation of the function CreateFont(). It is related to the size parameter by the default GDI aspect ratio and the natural aspect ratio of the chosen font.
font_angle
Allows you to modify the baseline angle of text in 0.1 degree increments anti-clockwise. Default=0.
interlaced
When enabled, reduces flicker from sharp fine vertical transitions on interlaced displays. It applies a mild vertical blur by increasing the anti-aliasing window to include 0.5 of the pixel weight from the lines above and below. Default=false.

Examples

# Some text in the center of the clip:
AviSource("D:\clip.avi")
Subtitle("Hello world!", align=5)
# Some text in the upper right corner of the clip with specified font, size and color:
AviSource("D:\clip.avi")
Subtitle("Hello world!", font="georgia", size=24, text_color=$ff0000, align=9)
# Prints text on multiple lines
# without any text halo border.
BlankClip()
Subtitle( \
  "Some text on line 1\\nMore text on line 1\n" + \
  "Some text on line 2", \
         lsp=10, halo_color=$ff000000)

# It results in:
Some text on line 1\nMore text on line 1
Some text on line 2
# Use String() to display values of functions.
AviSource("D:\clip.avi")
Subtitle("Width=" + String(Width()))

Changes

v2.60 position (x,y) can be float (previously int) (with 0.125 pixel granularity).
v2.58 Added font_width, font_angle, interlaced and alpha color blending.
v2.57 Added multi-line text and line spacing parameter.
v2.56 changed default align parameter: from "default = 4, if x == -1 then 5" to "default = 7, if x == -1 then 2"
v2.07 Added align and spc parameters. Setting y=-1 calculates vertical center (alignment unaffected). Default x and y values dependent on alignment (previously x=8, y=size).
v1.00 Setting x=-1 uses horizontal center and center alignment (undocumented prior to v2.07).


See also

There are external subtitling filters that display SRT, SSA, and other format subtitle files or offer more elaborate formatting.

Personal tools