Version 13 (modified by 6 years ago) (diff) | ,
---|

## Overview

Fonts with appropriate Unicode coverage and Open Font Format features are required for good math rendering. Maintainers of WebKit ports and operating systems should ensure that such fonts are available to get more reliable results on MathML tests and to maximize user experience. WebKit users encountering troubles with the rendering of MathML are encouraged to check that such a font is installed on their system. They are also invited to configure the default math font to match their preference.

## Recommended Math Fonts

Here is a list of known math fonts that can be used to render MathML formulas in WebKit:

- Asana Math
- Cambria Math
- DejaVu Math TeX Gyre
- Latin Modern Math
- Libertinus Math
- Lucida Bright Math
- Minion Math
- STIX Math
- TeX Gyre Bonum Math
- TeX Gyre Pagella Math
- TeX Gyre Schola Math
- TeX Gyre Termes Math
- XITS Math

This list essentially corresponds to known fonts that have an Open Font Format MATH table (for a complete list of required features and unicode coverage see the sections below). Latin Modern Math is recommended for users who are familiar with TeX's Computer Modern style. The STIX family provides the best unicode coverage but it has many bugs that will only be fixed in version 2 with a release planned for the third quarter of 2016. These two fonts form the recommended minimal set to consider for maintainers and the default option to try for users. XITS Math also has many features for Arabic and right-to-left math.

## Customizing Math Font

The default font-family on the `<math>`

tag is not inherited but set to a list of known math fonts. Authors or readers of MathML equations can easily customize it by adding the following CSS rule to the author/user style sheet:

math { font-family: "My Fancy Math Font"; }

For best rendering, it is recommended to use text font and math font that have consistent style. For example, authors can use the following stylesheet to display their page with the "Latin Modern" style:

body { font-family: "Latin Modern Roman"; } math { font-family: "Latin Modern Math"; }

For more information, see this page with Web fonts, sample CSS style sheets and online demos.

## Unicode Coverage

In order to display various scientific and technical symbols, math fonts should cover the largest possible subset of Unicode Character Ranges for Scientific Documents and more specifically:

Mathematical Alphanumeric Characters are required to display variables with their default mathematical italic style and to support the `mathvariant`

attribute. However, the former is currently done with CSS (bug 155018) and the latter is not implemented yet (bug 108778).

## Open Font Format features

Development is in progress to make our MathML support rely on TeX rules and Open Font Format features features. These Open Font Format features are available in the recommended math fonts listed above.

### MathConstants table

These are layout constants for example the default thickness of fraction bar. Here is the implementation status:

- ScriptPercentScaleDown: no
- ScriptScriptPercentScaleDown: no
- DelimitedSubFormulaMinHeight: no
- DisplayOperatorMinHeight: yes
- MathLeading: no
- AxisHeight: yes since r202973
- AccentBaseHeight: yes since r203074
- FlattenedAccentBaseHeight: no
- SubscriptShiftDown: yes since r199665
- SubscriptTopMax: yes since r199665
- SubscriptBaselineDropMin: yes since r199665
- SuperscriptShiftUp: yes since r199665
- SuperscriptShiftUpCramped: no (bug 156401)
- SuperscriptBottomMin: yes since r199665
- SuperscriptBaselineDropMax: yes since r199665
- SubSuperscriptGapMin: yes since r199665
- SuperscriptBottomMaxWith: yes since r199665
- SpaceAfterScript: yes since r199665
- UpperLimitGapMin: yes since r203074
- UpperLimitBaselineRiseMin: yes since r203074
- LowerLimitGapMin: yes since r203074
- LowerLimitBaselineDropMin: yes since r203074
- StackTopShiftUp: yes since r203073
- StackTopDisplayStyleShiftUp: yes since r203073
- StackBottomShiftDown: yes since r203073
- StackBottomDisplayStyleShiftDown: yes since r203073
- StackGapMin: yes since r203073
- StackDisplayStyleGapMin: yes since r203073
- StretchStackTopShiftUp: yes since r203074
- StretchStackTopShiftUp: yes since r203074
- StretchStackBottomShiftDown: yes since r203074
- StretchStackGapAboveMin: yes since r203074
- StretchStackGapBelowMin: yes since r203074
- FractionNumeratorShiftUp: yes since r202979
- FractionNumeratorDisplayStyleShiftUp: yes since r202979
- FractionDenominatorShiftDown: yes since r202979
- FractionDenominatorDisplayStyleShiftDown: yes since r202979
- FractionNumeratorGapMin: yes since r202979
- FractionNumDisplayStyleGapMin: yes since r202979
- FractionRuleThickness: yes since r199295
- FractionDenominatorGapMin: yes since r202979
- FractionDenomDisplayStyleGapMin: yes since r202979
- SkewedFractionHorizontalGap: no
- SkewedFractionVerticalGap: no
- OverbarVerticalGap: yes since r203074
- OverbarRuleThickness: no
- OverbarExtraAscender: yes since r203074
- UnderbarVerticalGap: yes since r203074
- UnderbarRuleThickness: no
- UnderbarExtraDescender: yes since r203074
- RadicalVerticalGap: yes
- RadicalDisplayStyleVerticalGap: yes since r202977
- RadicalRuleThickness: yes
- RadicalExtraAscender: yes
- RadicalKernBeforeDegree: yes
- RadicalKernAfterDegree: yes
- RadicalDegreeBottomRaise: yes

### MathGlyphInfo table

Currently, we only use italic correction to position subscripts of large operators (bug 153918).

### MathVariants table

This table is very important for displaying larger variants of operators (via the MathGlyphVariantRecord table) as well as stretching to an arbitrary size (via a GlyphAssembly table). Note that our support for glyph assemblies is limited to a restricted syntax with at most 3 pieces and a same extender connecting them. Some examples of why it is needed:

- operator in display style like big integrals, summation symbols, etc
- vertical stretching of radicals, fences, arrows etc
- horizontal stretching of accents, braces, arrows, etc

### Tags

Nothing has been implemented yet. The following tags should be considered: `math`

, `ssty`

, `flac`

, `dtls`

and `rtlm`

.

## Obsolete Fonts and Fallback Mechanisms

Some old fonts with good math Unicode coverage that do not have the Open Font Format features mentioned above can still be used to provide minimal support with the help of some fallback mechanisms included in WebKit. So for example:

- Everything that relies exclusively on Unicode coverage will work for these fonts too.
- stretched vertical parenthesis, brackets, braces, ceilings, floors, bars and integral sign can be drawn via the characters U+007C, U+2016, U+2225, U+2320, U+2321, U+239B, U+239C, U+239D, U+239E, U+239F, U+23A0, U+23A1, U+23A2, U+23A3, U+23A4, U+23A5, U+23A6, U+23A7, U+23A8, U+23A9, U+23AA, U+23AB, U+23AC, U+23AD, U+23AE instead of using the MathVariants table.
- stretched radical symbols are drawn with hardcoded drawing paths instead of reading the MathVariants table.

However, all of this should be considered a way to workaround the lack of proper math fonts. In particular, note that:

- Any larger variants or glyph assembly not listed above can not be done without the MathVariants table (e.g. stretched arrows, horizontal braces, big operators in display style etc).
- Layout constants from the MathConstants table are set to some arbitrary values based on x-height or font size (hence alignment, positions, shifts, gaps and so on may be bad or totally wrong).
- Italic correction from the MathGlyphInfo table is considered to be zero (so e.g. placement of subscript attached to integrals may be wrong).

See also bug 156837.