Version 7 (modified by 9 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
- 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
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. These two fonts form the recommended minimal set to consider for maintainers and the default option to try for users.
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, 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).
The following characters are also used to provide minimal operator stretching for fonts without a MATH table: 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.
Open Font Format features
Development is in progress to make our MathML support rely on TeX rules and OpenType features. These features should be available in math fonts.
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: partial (bug 133567)
- AccentBaseHeight: no (bug 155756)
- FlattenedAccentBaseHeight: no
- SubscriptShiftDown: yes (bug 153918)
- SubscriptTopMax: yes (bug 153918)
- SubscriptBaselineDropMin: yes (bug 153918)
- SuperscriptShiftUp: yes (bug 153918)
- SuperscriptShiftUpCramped: no (bug 156401)
- SuperscriptBottomMin: yes (bug 153918)
- SuperscriptBaselineDropMax: yes (bug 153918)
- SubSuperscriptGapMin: yes (bug 153918)
- SuperscriptBottomMaxWith: yes (bug 153918)
- SpaceAfterScript: yes (bug 153918)
- UpperLimitGapMin: no (bug 155756)
- UpperLimitBaselineRiseMin: no (bug 155756)
- LowerLimitGapMin: no (bug 155756)
- LowerLimitBaselineDropMin: no (bug 155756)
- StackTopShiftUp: no (bug 155714)
- StackTopDisplayStyleShiftUp: no (bug 155714)
- StackBottomShiftDown: no (bug 155714)
- StackBottomDisplayStyleShiftDown: no (bug 155714)
- StackGapMin: no (bug 155714)
- StackDisplayStyleGapMin: no (bug 155714)
- StretchStackTopShiftUp: no (bug 155756)
- StretchStackTopShiftUp: no (bug 155756)
- StretchStackBottomShiftDown: no (bug 155756)
- StretchStackGapAboveMin: no (bug 155756)
- StretchStackGapBelowMin: no (bug 155756)
- FractionNumeratorShiftUp: no (bug 155639)
- FractionNumeratorDisplayStyleShiftUp: no (bug 155639)
- FractionDenominatorShiftDown: no (bug 155639)
- FractionDenominatorDisplayStyleShiftDown: no (bug 155639)
- FractionNumeratorGapMin: no (bug 155639)
- FractionNumDisplayStyleGapMin: no (bug 155639)
- FractionRuleThickness: yes
- FractionDenominatorGapMin: no (bug 155639)
- FractionDenomDisplayStyleGapMin: no (bug 155639)
- SkewedFractionHorizontalGap: no
- SkewedFractionVerticalGap: no
- OverbarVerticalGap: no (bug 155756)
- OverbarRuleThickness: no
- OverbarExtraAscender: no (bug 155756)
- UnderbarVerticalGap: no (bug 155756)
- UnderbarRuleThickness: no
- UnderbarExtraDescender: no (bug 155756)
- RadicalVerticalGap: yes
- RadicalDisplayStyleVerticalGap: no (bug 155638)
- 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 proper display of integrals, radicals, fences etc Currently, we support search for a MathGlyphVariantRecord as well as simple constructions via a GlyphAssembly.
Tags
Nothing has been implemented yet. The following tags should be considered: math
, ssty
, flac
, dtls
and rtlm
.