6.S082 Lecture 20 Typography

Typography can enhance or hinder communication

Typography & Communication

font-family: Helvetica Neue, Segoe UI, sans-serif;
Serif typefaces
Typefaces with serifs. Older. More formal.
Sans serif typefaces
Typefaces without serifs. 1920+. More modern feel.

Are serif typefaces easier to read?

No.

The evidence does not show any difference either way.

Myth

What about preferences?

Serif headings, sans serif body text

Sans serif headings, serif body text

Variable width
Each character has a different width
Monospace
Each character has the same width. Typewriters, programming code.

Helvetica Neue  <— Font family / typeface

Baskerville <— Font family / typeface

Going beyond system fonts


		@font-face {
			font-family: Arvo;
			src: url(fonts/s.woff);
			font-weight: bold;
		}

		h1 {
			font-family: Arvo, sans-serif;
			font-weight: bold;
		}
	

Font file types

Extension
*.otf, *.ttf Font files. *.otf is OpenType, *.ttf is TrueType, a subset of OpenType.
*.woff, *.woff2 Web Open Font Format file Compressed font file for the Web. Prefer when available. WOFF 2 provides better compression.
*.ttc TrueType Collection: multiple faces in one file. Currently not supported in @font-face but there are plans for this.
*.eot Embedded OpenType file Older, IE-specific. Historically significant, but serves no purpose today.

What is in a font file?

Glyph. n. The visual representation of character(s)

Character
Smallest component of written language that has semantic value
Glyph
Visual representation of character(s)

é

character(s), glyph(s), font(s)

Accented characters

é

fi

character(s), glyph(s)

character(s), glyph(s)

ligature. (ˈlɪgəʧʊə)
n. characters joined together in one glyph to make a more aesthetically pleasing shape

OpenType Features

OpenType features

OpenType features & CSS

The first & final efficient flash select affliction

font-variant-ligatures: ;

1234567890ABC
1234567890abj

font-variant-numeric:  ;

1/2 3/4 5/8
13/27 86/483

font-variant-numeric: ;
112,113.56
89,546.87
286,111.10
font-variant-numeric: ;

1st, 2nd, 3rd, 4th

font-variant-numeric: ;

1er, 2e, 3e, 4e

font-variant-numeric: ;

C12H22O11 + HCl → CH3COH + ClO2 + H2O

font-feature-settings: ;

👨‍👨‍👧

character(s), glyph(s)

Emoji “ligatures”

👨‍👨‍👧 = 👨‍+ + 👨+ ‍ + 👧

👨‍👨‍👧

font-variant-ligatures: ;
Tofino family

37 files

Regular web font
37 files, about ~45KB each (1.5 MB total), discrete design space
Variable font
1 file, interpolate along design axes, ~90KB/axis (180 KB total), continuous design space

Deltas (Weight axis)

glyph outline deltas

Registered variation axes

Axis tag Name Descriptor/Property
'ital' Italic font-style
'opsz' Optical size font-optical-sizing
'slnt' Slant font-style
'wdth' Width font-stretch
'wght' Weight font-weight

Dunbar variable font

Using
variable
web fonts


	@font-face {
		font-family: "Dunbar";
		src: url("dunbar.otf");
		font-weight: 100 900;
		font-stretch: 50% 200%;
		font-style: -10deg 40deg;
	}

	h1 {
		font-weight: 234;
		font-stretch: 80%;
		font-style: oblique 24deg;
	}

🔥 If you want text of different sizes to *feel* like the same weight, make larger text thinner and smaller text bolder. pic.twitter.com/kgGQJJh1EL

— Steve Schoger (@steveschoger) March 28, 2018

Custom axes


		font-family: '-OC Format Shards', sans-serif;
		font-variation-settings: 'SHTR' ;
	
/* Decovar: An experimental variable font
   by David Berlow
   with multiple custom axes */
@font-face {
	font-family: "Decovar";
	src: url(fonts/decovar.ttf);
}

p {
	font-family: Decovar;
	font-variation-settings:     
	  "TRMC" [TRMC], /* Rounded slab */
	  "TRMB" [TRMB], /* Flared */
	  "SKLA" [SKLA], /* Inline Skeleton */
	  "TRMK" [TRMK]; /* Inline Terminal */
}

De co var

Discontinuous changes are possible

JAVA Table Water

font-kerning: ;
letter-spacing: 0em;

keming. (kĕmˈ-ĭng)
n. The result of
improper kerning.

Font Metrics

Adequate line spacing is necessary to make word shapes recognizable in a vertical dimension, but too much line spacing makes it harder for the eye to track back to the start of the next line. Line spacing is also called leading (pronounced like “ledding”). The leading is the distance between baselines of adjacent lines. Both font size and leading are important.

line-height: 1;

Leading & Accessibility

Character spacing

Sphinx 0
↕ 1em
↕ 1ex
↔ 1ch

“For people with some reading or vision disabilities, long lines of text can become a significant barrier. They have trouble keeping their place and following the flow of text. Having a narrow block of text makes it easier for them to continue on to the next line in a block. Lines should not exceed 80 characters or glyphs (40 if CJK), where glyphs are the element of writing in the writing system for the text.” — Web Content Accessibility Guidelines

max-width: 40em;

Justified alignment can really improve a layout, as it facilitates following the design principle of alignment on both sides. However, it can also break a layout when done sloppily and without care. Without hyphenation, there are often uneven spaces between words creating uncomfortable trapped space. The narrower the line width, the worse the problem. If a language is set in the HTML, CSS offers basic hyphenation via the hyphens property. Avoid justification on very narrow line widths; no amount of hyphenation will save you.

text-align: left; max-width: 40ch; hyphens: none;

Further typographic improvements

Ben Bitdiddle
Education
MIT, Cambridge, MA (2013-2016)
Publications
"7x8: A harder - and subtler - problem than previously recognized." Journal of Resume Padding, 2014
Ben Bitdiddle
Education
MIT, Cambridge, MA (20132016)
Publications
7×8: A harder — and subtler — problem than previously recognized.” Journal of Resume Padding, 2014

Punctuation

Color fonts

From illuminated manuscripts…

…to emoji

😀 😎 🤖👧‍👦 👦🏻 👧🏻 👨🏻 👩🏻 👦🏼 👧🏼 👨🏼 👩🏼 👦🏽 👧🏽 👨🏽 👩🏽 👦🏾 👧🏾 👨🏾 👩🏾 👦🏿 👧🏿 👨🏿 👩🏿 🤱🏽👶🏼 👶🏿 👪 👨‍👩‍👧 👨‍👩‍👧‍👦 👨‍👩‍👦‍👦 👨‍👩‍👧‍👧 👩‍👩‍👦 👩‍👩‍👧 👩‍👩‍👧‍👦 👩‍👩‍👦‍👦 👩‍👩‍👧‍👧 👨‍👨‍👦 👨‍👨‍👧 👨‍👨‍👧‍👦 👨‍👨‍👦‍👦 👨‍👨‍👧‍👧👩‍👦 👩‍👧 👩‍👧‍👦 👩‍👦‍👦 👩‍👧‍👧 👨‍👦 👨‍👧 👨‍👧‍👦 👨‍👦‍👦 👨‍👧‍👧 🐱 🐶 🐌 🌎 🍕 🍲 🍫 🍻 ⚽️ 🏀 🏈 ⚾️ 🌈 🏯 🗽 🚆 📱 🎉 🗓 💸 🇺🇸 🇧🇷 🇲🇹 🇸🇪 🇳🇬 🇰🇭 🇭🇷 🇮🇩 🇳🇿 🇪🇬 🇫🇮 🇨🇳

Four different technologies

@font-face {
	/* By Pixel Ambacht */
	font-family: "Poo";
	src: url(fonts/poo.ttf);
}

p {
	font: 600%/1 Poo;                   
	font-variation-settings: "crap" [crap];
}

💩