Determining ex, em and en
Simon Cozens
Posts: 752
I'm writing some typography software which allows users to specify lengths in various dimensions.
If the user asks for a length of "1ex", is it reasonable to determine this length from the sxHeight entry in the OS/2 table? Should I be literally measuring the point height of an "x" in the font instance? Or something else?
Similarly for "1em" - I'm just using the point size of the font instance but should I be doing something more clever?
And "1en" - half an em?
If the user asks for a length of "1ex", is it reasonable to determine this length from the sxHeight entry in the OS/2 table? Should I be literally measuring the point height of an "x" in the font instance? Or something else?
Similarly for "1em" - I'm just using the point size of the font instance but should I be doing something more clever?
And "1en" - half an em?
0
Comments
-
em and en, yes, should be equal to nominal font size and half of same, respectively.
For ex, I'd be inclined to use the sxHeight entry in the OS/2 table, on the basis that if it isn't actually equal to the lowercase x height, there might be some good reason for that, e.g. the font doesn't contain a Latin lowercase!0 -
Why are you doing this, Simon?
Shouldn’t these characters be a function of the font, not the layout app?0 -
Thanks, John! Nick, I'm not defining characters, I'm defining units of measurement. ("Set interline distance to 1.2em" and so on.)0
-
BTW, my general recommendation would be to match CSS use of these units.1
-
Good idea... although now I discover neither Harfbuzz nor Freetype supports interrogating the sxHeight field, this may all become a little academic. Time to go digging in browser source code to see how they do it.0
-
FreeType: http://www.freetype.org/freetype2/docs/reference/ft2-truetype_tables.html#TT_OS2
HarfBuzz: Well, you can extend the OS/2 support (that you wrote initially ) to read later version of the table and provide x-height.
0 -
Firefox with FreeType seems to try measuring the height of x, then sxHeight, then half em.
0 -
For completeness:
- Mozilla, when using Freetype measures the height of /x in units, with the following comment: "Prefering a measured x over sxHeight because sxHeight doesn't consider hinting, but maybe the x extents are not quite right in some fancy script fonts. CSS 2.1 suggests possibly using the height of an "o", which would have a more consistent glyph across fonts."
- Mozilla, when not using Freetype, tries to load sxHeight from the OS/2 table, ignoring negative values. If that doesn't work and you're on a Mac, it calls CGFontGetXHeight. It then tries to measure characters and if that fails, multiplies the maximum ascent by 0.56.
- Chromium uses Skia, which checks OS/2 then measures an "X", and then gives up and uses the ascender(!)
0 -
And which using DirectWrite it uses whatever value DirectWrite calculates for the font metrics.
I’d say go for sxHeight (you don’t need to account for hinting) falling back to half em, and call it a day.
1
Categories
- All Categories
- 43 Introductions
- 3.7K Typeface Design
- 805 Font Technology
- 1.1K Technique and Theory
- 622 Type Business
- 445 Type Design Critiques
- 542 Type Design Software
- 30 Punchcutting
- 137 Lettering and Calligraphy
- 84 Technique and Theory
- 53 Lettering Critiques
- 486 Typography
- 304 History of Typography
- 114 Education
- 68 Resources
- 500 Announcements
- 80 Events
- 105 Job Postings
- 149 Type Releases
- 165 Miscellaneous News
- 270 About TypeDrawers
- 53 TypeDrawers Announcements
- 116 Suggestions and Bug Reports