SVG and Typography
April 7, 2004
Fabio Arciniegas A.
Editor's Note: SVG is back in style on XML. Fabio Arciniegas and Antoine Quint will
be
covering typography, video and mobile topics over the coming weeks.
Mixing the worlds of documents, programming, and visual design is a familiar experience
for
XML developers, especially when dealing with presentation technologies like SVG. Such
mixtures can produce exciting new representations of information. They can also become
ugly
messes if one fails to learn the relevant aesthetic and design principles.
data:image/s3,"s3://crabby-images/e047c/e047cfcd1022e122d0238b15f2a28f007e173d94" alt="" |
Fig.1 Type can be essential for Charts, Diagrams, and GUIs, as
well as for Artistic Works |
One aspect that you want to get a good grasp on, if you work with SVG, is typography.
Few
things have its power to make or break a visual work. The goal of this article is
to review
key ideas about typography so that you can use it effectively, either by applying
the rules
in visual explanations and GUIs or by bending the rules in your artistic output (Fig.1.)
This article is divided in four parts, each corresponding to a particular area of
the
combination of SVG and typography:
Foundations and Character Treatment
Position, Alignment, Direction, Colors, Fonts
Character Treatment
Hyphens, Quotations, Spaces, Symbols, Ligatures, Non-Latin characters
Static Design Strategies implemented on SVG
Crop, Backward/Forward,
Blur, Contour, Crowd, Contrast Weight, Gradation, Highlight, Path, Outline, Overlap,
Repeat,
Reverse, Shadow, Tilt
Dynamic Presentation Strategies implemented on SVG
Fade ins, Color
Tweening, Scrolling, Type Effect, Bounce, Animate through contour,Size Transitions,
Menus,
Montage.
Before we begin, please make sure you have the Adobe SVG plug in installed,
as most images from this point on are SVG.
Foundations
Using the text
element, its attributes, and CSS styling one can position and
format glyphs in SVG in the ways one has come to expect in desktop graphics. The following
sections outline the basics and the particular features SVG offers for their treatment.
Positioning, Alignment, Direction
Positioning of text in SVG appears quite obvious: The two attributes x
and
y
determine the position of the text:
<text x="44" y="62">Hello World</text>
Position
That's only the beginning of the story. The first thing to point out is that the values
accepted by x
and y
are lists of points, not necessarily single
values. Positioning, therefore, is not restricted to just one value for the beginning
of the
text but can be specified independently for each glyph of the text, as illustrated
in the
billboard of Listing 1:
<?xml version="1.0"?>
<svg xmlns="http://www.w3.org/2000/svg" width="350"
height="155" version="1.1">
<rect x="1" y="1" width="320"
height="130"
style="fill:#008683; stroke:black;"/>
<g style="font-family:Beachman Script; font-size: 36pt; fill:#D5E9D7">
<text x="22 47" y="62 65">TheMerryWives</text>
<text x="150" y="100">ofWindsor</text>
</g>
</svg>
Listing 1 Positioning