Comparison of layout engines (web typography)
The following tables compare support for different font formats and support for CSS3 font resources for a number of layout engines. Web fonts were initially defined (but later dropped) from CSS2, then added into CSS3. The specification is supported by an increasing number of web browsers.[1][2]
Explanation of the tables
Engine nomenclature
Rather than the names of web browsers and HTML to PDF converters, the names of the underlying engines are used. Some of the software and online converters that use the various engines are listed below.
Layout engine |
Release version |
Preview version |
Used by |
Amaya |
11.4.7[3] |
N/A |
No longer developed; Amaya |
Blink |
537.36 |
source code[note 1] |
Chromium/Chrome (28+), Opera (15+), Sleipnir, Vivaldi, Yandex, Liebao and Samsung Browser . |
EdgeHTML |
13.10586 [4] |
N/A |
Microsoft Edge, Universal Windows Platform (UWP) JavaScript apps |
Gecko |
Standard |
50.0.2 / November 30, 2016 (2016-11-30)[5] |
---|
ESR |
45.5.1 / November 30, 2016 (2016-11-30)[6] |
---|
|
Beta |
51.0beta / November 16, 2016 (2016-11-16)[7][8] semiweekly release |
---|
Developer Edition |
52.0a2 / November 18, 2016 (2016-11-18)[9][10] daily release |
---|
Nightly |
53.0a1 / November 14, 2016 (2016-11-14)[11][12] daily release |
---|
|
All Mozilla software, including Firefox; SeaMonkey and Galeon; Camino; K-Meleon; Flock (up to 2.x); Debian IceWeasel; GNU IceCat (formerly GNU IceWeasel); Cyberfox; Icedove, Iceape and Iceowl; Firefox for mobile ("Fennec"). Also used by the Maple platform in 2010 and 2011 Samsung "SmartTV" devices which are based on the build used in Firefox 2.5. The Nokia Asha platform also uses Gecko for web apps rendering. |
Goanna |
27.0.2 (December 2, 2016 (2016-12-02)[13]) [±] |
27 public beta 3 (October 27, 2016 (2016-10-27)[14]) [±] |
Pale Moon and FossaMail |
KHTML |
4.12.3[15] |
N/A |
Konqueror[note 2] |
Martha |
? |
? |
PDFreactor, Nimbudocs Editor and edit-on NG |
Presto |
2.12.388 |
N/A |
No longer developed; Opera and Opera Mobile use Blink now; Nintendo DS & DSi Browser; Internet Channel |
Prince |
10 |
20160810 |
HTML to PDF converters: Prince (previously called PrinceXML), DocRaptor. The information in the Prince columns is also true of Prince for Books, a related layout engine. |
Tasman |
(IE 5.2.3 for Mac) |
N/A |
No longer developed (aborted in 2003); Internet Explorer 5+ for Mac OS X |
Trident |
7.0 (IE 11) |
N/A |
Internet Explorer and other Internet Explorer shells like Maxthon (Microsoft Windows operating systems only), Windows Phone 8 |
WebKit |
534.20 |
nightly build[note 3] |
Tizen (both OS and browser), Safari (both desktop and mobile), Google Chrome (before 28), Maxthon 3, Shiira, iCab 4, OmniWeb 5.5+, Web, Adobe AIR, Midori, surf, Adobe Dreamweaver CS4 and CS5, Android browser, Palm webOS browser, Symbian S60 browser, OWB, Steam, Rekonq, Arora, Flock (version 3+), RockMelt, Dolphin Browser, Konqueror[note 2]. Used by the LG Smart TV platform to enable web content on TVs. HTML to PDF converters: wkhtmltopdf, PhantomJS, Pdfcrowd[16], http://www.online-convert.com/[17]. |
Values
Values indicate the level of support in the most recent version of the layout engine, or (if a version number is given) in the specified version. Version numbers without any other value indicate the version at which the layout engine first fully supported the feature.
Value |
Meaning |
Yes |
Indicates that the layout engine fully supports this property/element when valid values are used. |
No |
Indicates that the property/element is completely ignored. |
Partial |
Indicates that the property/element is understood, but that not all values are supported. Supported values are implemented correctly. |
Incorrect |
Indicates that the property/element is understood, but that it is not implemented correctly in all cases. |
Experimental |
Indicates that the property/element is understood, but supported under an alternate name. May be incomplete or buggy. |
Dropped |
Indicates that the property/element is no longer supported. |
Nightly build |
Indicates that the property/element is supported to some extent in an experimental/nightly build. Future support is expected. |
Depends |
Indicates that the property/element is supported only on certain platforms, or if certain settings are configured. |
Support for CSS font resources
CSS3 specified a mechanism for downloading and displaying fonts within a web page.[spec 1] This table compare support for that mechanism. Note that Embedded OpenType (EOT)[spec 2] font download does not bring in the entire OpenType font and therefore, the most prominent feature of Open Type, ligature support, does not come with EOT. Trident before version 5.0 supports only EOT. EOT is not sufficient for smartfonts that rely on ligatures.
Support in HTML and XML documents
This table compares support for font formats applied with the @font-face
rule in HTML and XML documents.
Support in SVG documents
This table compares support for font formats applied with the @font-face
rule in SVG documents.
Smart font features support
See also
Notes
References
- Specifications
- ↑ CSS Fonts Module Level 3 - Font resources, W3C
- 1 2 3 Nelson, Paul (2008-03-05), Embedded OpenType (EOT) File Format, Microsoft, Monotype Imaging
- 1 2 TrueType Reference Manual, Apple
- 1 2 OpenType specification, Microsoft
- 1 2 Scalable Vector Graphics (SVG) 1.1 Specification - Fonts, W3C
- 1 2 Kew, Jonathan; Leming, Tal; van Blokland, Erik (2010-04-08), WOFF File Format 1.0, W3C, Mozilla, Type Supply, LettError
- 1 2 Kew, Jonathan; Leming, Tal; van Blokland, Erik (2009-10-23), WOFF File Format, Mozilla, Type Supply, LettError
- ↑ OpenType Layout tag registry, Tag: 'liga', Microsoft
- ↑ OpenType Layout tag registry, Tag: 'rlig', Microsoft
- Trident references
- Gecko references
- WebKit references
- ↑ Hyatt, Dave (2007-10-03), Downloadable Fonts, Apple
- ↑ Issue 9633: Disable web fonts by default, Google, 2009-04-01
- ↑ Full pass of acid3 - Chromium-dev, Google, 2009-07-03
- ↑ Issue 17818: Enabled dynamic / web font support in a secure manner, Google, 2009-07-27
- ↑ Irish, Paul (2010-01-25), Chrome and @font-face: It's here!
- ↑ Bug 12530 - CSS3: Support the font-stretch property, WebKit
- ↑ @font-face support in Safari
- 1 2 Bug 20542 - Adding EOT Font Rendering capability, WebKit
- 1 2 Bug 31302 - Add WOFF support for @font-face, WebKit
- ↑ Bug 38217 - [chromium] Add WOFF support, WebKit
- ↑ Irish, Paul (2010-08-02), Quick Guide to Implement Webfonts via @font-face, HTML5Rocks
- ↑ On Safari, ligatures may be switched on with the CSS setting text-rendering, but then, they are used indiscriminately even when letter-spacing is increased (see Fraktur letterspacing); on Google Chrome, ligatures do not work.
- Presto references
- Other references