Styles
A style in the ASS format is a set of typographic formatting rules that is
applied to dialogue lines. The style parameters can be overridden with
override tags; the styles exist so that you won't have to type out
all the overrides for each line.
The styles manager
Aegisub's styles manager tool (accessed from the Subtitles menu) provides
various means of organizing, saving and editing styles. It looks like this:
As you can see, the window is divided into two halves. The right half displays
all styles that you currently have accessible in your currently loaded script;
the left represents a style storage. Style storages are used by Aegisub to let
you save styles and quickly import them into scripts. You can have as many
storages as you want; some people prefer to keep all their styles in one
storage, others sort their styles by font, by show or alphabetically. The drop
down menu at the top lets you choose what storage you want to view.
In the bottom part of the window there's two almost identical sets of buttons;
one set for the storage and one for the current script. They are:
- New
- Create a new style, either in the storage or in the current script.
- Edit
- Edit the selected style using the style editor (see below).
- Copy
- Create a copy of the selected style and bring up the style editor for it.
- Delete
- Delete the selected style(s).
- Copy to script and Copy to storage
- Copies the selected styles between the storage and the current script.
- Import from script
- Import one or more styles from another script to the current one.
Pressing Ctrl-C in the styles manager will copy the selected style(s) to the
clipboard as a text string. This also works the other way around; you can copy
one or more style lines from another program and press Ctrl-V (paste) in the
styles manager; this will insert them into the current script.
The style editor
Pressing the "Edit" button or double clicking a style name will bring up the
style editor, which lets you tweak all the parameters available. Note: some
parameters that are available as override tags (i.e. \be
) are not available
as style parameters; conversely, some parameters that are available in the
styles editor (i.e. the "opaque box" outline option) are not available as a
style override. This is an unfortunate and occasionally annoying format
limitation.
To return to the style editor:
- Style name
- The name of the style. You can't have two styles with the same name in the
same script.
- Font
- This section controls the font settings. The drop down menu lets you choose
the typeface (any font installed on your system will show up in this list) and
the number to the right controls the size in points. The check boxes below set
the bold/italic/underline/strikeout parameters.
- Colors
-
This controls the four text colors (primary, secondary, outline and shadow).
The meaning of each of them is as follows:
- Primary
- The main "fill" color of the body of the text.
- Secondary
- Secondary fill color, used for karaoke effects (see
\k
and its
relatives on the override tags page).
- Outline
- The border color of the text.
- Shadow
- The color of the shadow, which is displayed under the main text and
offset by the shadow width defined to the right.
The four colored boxes show you the current color for each of the four text
colors; clicking on them opens the color picker.
- Margins
- Controls how close to the borders of the video frame the text will be
positioned (and hence also when automatic line breaking will kick in; but do
note that there is no option for text justification). Each value (left, right,
vertical) is given in script resolution pixels (see script
properties). For alignments (
\an
) 1-3, the vertical margin is
relative to the bottom of the video frame; for 4-6 it doesn't have any meaning,
and for 7-9 it is relative to the top of the video frame.
- Alignment
- Controls the alignment of the text. The numbers correspond to the arguments
to the
\an
tag. Alignments 1, 4 and 7 are flush left; 3, 6 and 9 are flush
right; 2, 5 and 8 are centered. 1, 2 and 3 are "subtitles" (i.e. drawn at the
bottom of the frame); 4, 5 and 6 are "midtitles" (i.e. entered vertically on
the frame); 7, 8 and 9 are "toptitles" (i.e. drawn at the top of the frame). Do
note that there is no such thing as a justified alignment; this is a format
limitation.
- Outline
- Controls the outline (border) thickness (and style) and the shadow offset.
- For the outline, the number is the thickness of the border in script pixels
if ScaledBorderAndShadow is enabled (see script properties);
if it is disabled the thickness is given in video pixels instead. Setting
it to 0 disables the outline.
- The shadow on the other hand is a copy of the main text, shifted down and
to the right the specified distance. The distance is in script pixels if
ScaledBorderAndShadow is enabled, and video pixels otherwise. Setting it to
0 disables shadow.
- Finally, the check box marked "Opaque box" controls whether the outline
should be drawn as described above (which happens if it is unticked), or
replaced by an opaque background bounding box. Note that the rendering of
Opaque box outlines is broken when the font scale is anything other than
100%.
- Miscellaneous
-
This section has various other parameters, namely:
- Scale X/Y
- Controls text stretching in the horizontal (X) and vertical (Y) direction
respectively. The value is given in percent, so 100 means no stretching is
done. You should not use this for normal text sizing; use the point value
in the Font area instead since that uses hinting information from the font.
- Rotation
- Controls rotation of the text. The value is the angle of the rotation in
degrees (360 degrees to a full circle) and may be negative or larger than
360 (setting it to 360, 720 etc. is the same as setting it to 0 except for
when animated transforms are involved).
- Spacing
- Controls the horizontal spacing between letters. 0 means the font
defaults are used. May be negative for less spacing, or positive for more.
The value is the additional gap in pixels between each character; whether
these are script pixels or video pixels is not well defined.
- Encoding
- Controls which codepage is used to map codepoints to glyphs; it has
nothing to do with the actual text encoding of the script. This is only
meaningful on Windows using VSFilter, where it is used to get some old
(particularly Japanese) fonts without proper Unicode mappings to render
properly. On other systems and renderers, Freetype2 provides the proper
mappings. If you didn't understand a word of the above, pretend this
setting doesn't exist, as it is rarely important.
- Preview
- Shows a preview of what the text will look like using the current style
parameters. The text field lets you input some sample text to preview, and
the colored box controls the color of the background.
{: .horizontal-narrow}