Des fontes, une famille

Sous Adobe Photoshop, une famille de fontes au grand complet comme Adobe Myriad Pro apparait comme une fonte à 40 styles. Sous Microsoft Word 2007, comme 10 fontes à 4 styles. Qu’est-ce qui provoque cela ?

Structure d’une fonte

Dans une fonte Type 1, le nom d’une fonte est stocké dans un dictionnaire public (stockage différent selon la plateforme Mac, Windows ou Unix). Il y a plusieurs informations optionnelles, mais une entrée obligatoire est FontName, souvent constituée par convention en deux parties, le nom de la famille de la fonte et le nom de son style, jointes par un trait d’union, comme ceci, par exemple : MyriadPro-Semibold (il s’agit donc de la fonte Myriad Pro Semibold).

Dans une fonte OpenType (toute fonte à extension .ttf ou .otf), l’information de nom et de famille est stockée dans la table name. Assez complexe, chaque enregistrement étant associé à une plateforme, un codage et une langue (cette dernière association étant, hormis pour les fontes Microsoft, rarement employée). Pour simplifier, on ne retiendra que quelques enregistrements (nameID) principaux :

GDI, la source du mal

Pourquoi une telle complexité ?

L’essentiel du problème vient de l’API GDI (héritée de Microsoft Windows 3.1 et qui reste la base pour l’immense majorité des applications tournant sous Windows). GDI ne propose que des fontes à 4 styles, toujours les mêmes : romain, gras, italique, gras italique. Pour rendre une fonte comme la Myriad Pro Semibold compatible avec ce système, il faut la faire rentrer, de force forcée, dans ce système rigide à 4 styles. Voici ce que l’on peut observer si on l’ouvre avec FontLab Studio :

Capture d’écran de FontLab Studio, fenêtre 1

Propriété de la fonte Myriad Pro Semibold sous FontLab Studio, première fenêtre.

Capture d’écran de FontLab Studio, fenêtre 2

Propriété de la fonte Myriad Pro Semibold sous FontLab Studio, deuxième fenêtre.

Les applications GDI vont lire l’enregistrement 1 (GDI ignore les enregistrements 16 et suivants, qui n’existaient pas à l’époque de sa création) de la table name (identifié sous FontLab comme « Family Name ») et vont donc voir cette fonte comme étant « Myriad Pro Light », style gras (case cochée « font is bold »). Par contre, une application moderne comme Illustrator, InDesign, Photoshop, ou encore Flash depuis sa version CS4, lira les enregistrements 16 et 17 (notés sous FontLab comme « OpenType-specific names ») et la considèrera comme la fonte « Myriad Pro », style « Semibold ».

En répétant les contorsions du premier cas, les quarante styles de la Myriad Pro pourront être vus comme dix familles différentes, à quatre styles chacune. Le second cas étant libre de toute contrainte de ce type, toutes les variantes de Myriad Pro seront bien considérées comme appartenant à une seule famille.

C’est d’ailleurs la totale liberté laissée pour l’enregistrement 17 qui a conduit Microsoft à proposer les enregistrements 21 et 22 : le style indiqué dans l’entrée 22 ne peut être qu’un des styles prévus par l’API WWS, qui reprend les styles prévus par la spécification CSS3. On limite ainsi la créativité, mais on s’assure de la compatibilité entre fontes : changer de fontes dans une application ne devrait pas obligatoirement faire perdre le style choisi. Mais pour l’instant, les applications utilisant WWS sont d’importance et de nombre négligeables.

Et ailleurs ?

Les applications tournant sous Mac OS X connaissent différentes variations du problème : Mac OS n’a jamais eu les contraintes de GDI, mais les applications importées de Windows, comme Microsoft Office, l’ont, et donc le système n’est pas totalement unifié dans sa gestion des fontes. Il est de plus bien évident qu’une compatibilité multiplateforme, spécialement en PAO, ne peut reposer que sur des applications ayant dépassés les contraintes de GDI : on imagine les soucis causés par un document InDesign utilisant la Myriad Pro Semibold sous Mac OS qui n’arriverait pas à la trouver sous Windows faute de la reconnaitre comme la Myriad Pro Light, style gras. Heureusement, Adobe, à la différence de Quark pour XPress, a prévu cette compatibilité dès InDesign 1.0 et plus tard pour ses autres produits phares en établissant son menu de fontes à partir des nouvelles entrées de la table name introduites par les spécifications OpenType.


Références (autres que celles citées dans le texte) :

Bug 420628 — Font Family name’s are not listed in font preference dialogs when there are “Preferred Family” names

Bug 454514 — Implement better style linking of font families under Windows