--- title: font-variation-settings slug: Web/CSS/font-variation-settings tags: - CSS - Propriété - Reference translation_of: Web/CSS/font-variation-settings ---
La propriété CSS font-variation-settings
permet de contrôler les caractéristiques typographiques de bas niveau OpenType ou TrueType en utilisant les quatres lettres représentant les axes des caractéristiques qu'on souhaite faire varier, ainsi que les valeurs pour les variations associées.
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
Cette propriété fonctionne à un niveau plus bas que {{cssxref("font-feature-settings")}} qui permet de définir les valeurs et les étiquettes (tags) pour les caractéristiques des polices.
font-variation-settings
l'emporteront sur celles définies par les autres propriétés relatives aux polices (ex. font-weight
), où qu'elles soient dans la cascade. Pour certains navigateurs, cela se vérifie uniquement lorsque la déclaration @font-face
inclut un intervalle font-weight
./* Valeur pour les réglages par défaut */ font-variation-settings: normal; /* Utilisation des valeurs */ /* pour les axes OpenType */ font-variation-settings: "XHGT" 0.7; /* Valeurs globales */ font-variation-settings: inherit; font-variation-settings: initial; font-variation-settings: unset;
La valeur de cette propriété peut être définie selon deux formes :
normal
<string>
) suivi d'un nombre (<number>
). Ce motif peut être répété tant qu'une virgule sépare chacun des tuples.normal
<string> <number>
<string>
a plus ou moins de 4 caractères et contient des caractères en dehors de l'intervalle U+20 - U+7E, la propriété sera considérée comme invalide. La valeur numérique <number>
n'est pas nécessairement entière et positive, ce peut être un nombre décimal ou un nombre négatif.{{csssyntax}}
Les axes des polices variables sont rangés selon deux catégories : les axes enregistrés et les axes spécifiques.
Les axes enregistrés représentent les variations les plus fréquemment utilisées. Si ces axes sont suffisamment fréquents pour avoir été standardisés, cela ne signifie pas qu'un créateur de police doive tous les gérer pour créer une police.
Voici la liste des axes enregistrés et les propriétés CSS correspondantes, qui permettent de jouer sur ces axes :
Étiquette pour l'axe | Propriété |
---|---|
"wght" | {{cssxref("font-weight")}} |
"wdth" | {{cssxref("font-stretch")}} |
"slnt" (slant) | {{cssxref("font-style")}}: oblique + angle |
"ital" | {{cssxref("font-style")}}: italic |
"opsz" |
{{cssxref("font-optical-sizing")}} |
Les axes spécifiques peuvent correspondre à n'importe quel axe que le concepteur de la police souhaite faire varier (ce peut par exemple être la hauteur des hampes et des jambages, la taille des empattements ou tout autre chose). N'importe quel axe peut être utilisé tant qu'il a une étiquette unique sur quatre caractères. Il est possible que, si des axes spécifiques deviennent majoritairement présents, ils soient intégrés parmi les axes enregistrés.
Note : Les étiquettes des axes enregistrés sont écrits en minuscules et les axes spécifiques doivent être écrits en majuscules. On notera que rien n'oblige à suivre cette règle et qu'il est tout à fait possible que des concepteurs de polices donnent des étiquettes en minuscules à des axes spécifiques. Quoiqu'il en soit, on retiendra que les étiquettes des axes sont sensibles à la casse.
Attention ! Afin de pouvoir utiliser les polices variables, votre système d'exploitation doit être à jour et votre navigateur doit prendre en charge ces fonctionnalités. Ainsi, les systèmes basés sur Linux requièrent la dernière version de Linux Freetype et les systèmes macOS antérieurs à 10.13 ne prennent pas en charge les polices variables.
wght
)L'exemple suivant peut être édité afin de voir l'effet de la modification des valeurs pour la graisse du texte.
slnt
)L'exemple suivant peut être édite afin de voir l'effet de la modification des valeurs pour la pente (à ne pas confondre avec l'italique) du texte.
Spécification | État | Commentaires |
---|---|---|
{{SpecName('CSS4 Fonts', '#low-level-font-variation-settings-control-the-font-variation-settings-property', 'font-variation-settings')}} | {{Spec2('CSS4 Fonts')}} | Définition initiale. |
{{cssinfo}}
Pour contribuer à ces données de compatibilité, vous pouvez envoyer une pull request sur ce dépôt: https://github.com/mdn/browser-compat-data.
{{Compat("css.properties.font-variation-settings")}}