- Police libre contenant des glyphes (formes de caractères) pour les caractères Unicode du monde entier, maintenue dans le cadre du projet GNU
- À partir de la version 15.1.01, un nouvel encodage combinatoire (méthode 6/3/1) a été introduit grâce aux contributions de Minseo Lee et Ho-seok Ee, avec un système de glyphes hangul amélioré
- Dans la version la plus récente, 17.0.03, de nombreux glyphes ont été corrigés ou ajoutés, notamment des sinogrammes chinois et japonais ainsi que des symboles arabes et musicaux
- Prend en charge l’intégralité des 65 536 points de code du BMP (Basic Multilingual Plane), et étend progressivement aussi les zones SMP (Supplementary Multilingual Plane) et CSUR (ConScript Unicode Registry)
- Distribuée sous double licence avec GNU GPLv2+ avec exception d’intégration de police et SIL Open Font License 1.1, ce qui permet une utilisation libre même dans des logiciels commerciaux
- Projet de police Unicode open source emblématique visant une couverture complète des systèmes d’écriture du monde entier
Présentation de GNU Unifont
- GNU Unifont est une police qui contient des glyphes pour tous les points de code Unicode imprimables, maintenue comme partie intégrante du projet GNU
- Prise en charge complète du plan multilingue de base (BMP, U+0000~U+FFFF)
- Extension continue du plan multilingue supplémentaire (SMP, U+010000~U+01FFFF) ainsi que des zones CSUR/Under-CSUR
- Utilisable aussi dans des logiciels commerciaux, mais les polices dérivées doivent être publiées sous la même licence
- Les licences sont GNU GPLv2+ (avec exception d’intégration de police) et SIL Open Font License 1.1
- La publication des polices dérivées garantit l’intérêt public
Droit d’auteur et licence
- Les milliers de glyphes sont des créations de contributeurs individuels, protégées par les lois nationales sur le droit d’auteur
- Certains reprennent des formes de caractères existantes, d’autres sont des icônes ou symboles conçus, bénéficiant d’une protection internationale encore plus forte
- Un mémorandum relatif au droit d’auteur allemand est publié
- Depuis Unifont 13.0.04, le projet est distribué sous double licence GPL 2+ / SIL OFL 1.1
- L’intégration (embed) de la police dans un document ne constitue pas une violation de la GPL
Téléchargement et formats de police
- Fournit une version standard ainsi qu’une version incluant les glyphes PUA CSUR/Under-CSUR
- Prise en charge de nombreux formats comme OpenType (.otf), PCF, BDF, PSF, HEX, etc.
- Installation possible sur Windows et macOS ; dans le terminal macOS, il faut activer l’option Antialias pour une bonne lisibilité
- Certains moteurs de rendu ignorent les informations d’espacement des glyphes, ce qui peut entraîner des erreurs d’affichage dans les moteurs strictement monospace
Limites d’Unifont
- Un seul glyphe est stocké par point de code imprimable
- Les écritures indiennes (devanagari, bengali, tamoul, etc.) ou les caractères dont la forme varie selon la position (comme l’arabe) ne sont donc pas rendus avec exactitude
- Pour les écritures complexes, l’usage de polices OpenType spécialisées est recommandé
Contribution de nouveaux glyphes
- Pour ajouter de nouveaux glyphes, un contact préalable par e-mail est nécessaire
- Cela permet de participer après concertation afin d’éviter les doublons
- Les glyphes hanzi 15×16 pixels (Plans 2 et 3) dont le gouvernement chinois détient les droits d’auteur ne peuvent pas être inclus dans une police libre
Dernières versions — Unifont 17.0
- Version 17.0.03 du 1er novembre 2025
- Correction de plus de 100 sinogrammes contenant les clés chinoises de ‘馬’ (cheval) et ‘鳥’ (oiseau)
- Intégration des listes normatives de caractères simplifiés chinois publiées entre 1935 et 2013
- Inclusion de la norme moderne des clés de caractères d’usage courant publiée en 2009
- Version 17.0.02 du 18 octobre 2025
- Nombreuses contributions de Paul Hardy, David Corbett, 晓晓Akatsuki, Boris Zhang et d’autres sur les plans 0 à 3
- Nombreuses corrections sur l’arabe, les symboles d’échecs, les extensions CJK, etc.
- Version 17.0.01 du 9 septembre 2025
- Ajout de l’Arabic Extended-B, de symboles monétaires, de caractères télougou et kannada, etc.
- Ajout, sur les plans 1 à 3, de nombreuses écritures comme Arabic Extended-C, Sidetic, Tolong Siki, Beria Erfe, Adlam, etc.
Principales versions précédentes
- Unifont 16.0 (premier semestre 2025)
- Nombreuses corrections en arabe, grec, hangul, symboles musicaux, etc.
- Ajout d’écritures CSUR comme Sitelen Pona et Zbalermorna
- Unifont 15.1 (2024)
- Introduction du codage Johab 6/3/1 pour le hangul combinatoire proposé par Ho-seok Ee
- Passage de la construction par défaut à OpenType au lieu de TrueType
- Améliorations majeures du hangul, des extensions CJK et des glyphes Wen Quan Yi
Couverture des glyphes
- Large prise en charge des plans Unicode jusqu’aux plans 0 à 3, 14 et 15
- Plan 0 : plan multilingue de base (couverture complète de tous les caractères majeurs)
- Plan 1 : plan multilingue supplémentaire (symboles musicaux, hiéroglyphes, écritures anciennes, etc.)
- Plans 2 à 3 : sinogrammes CJK étendus
- Plan 14 : tags et sélecteurs de variante
- Plan 15 : zone privée CSUR/Under-CSUR
Écritures CSUR et UCSUR
- Tengwar, Cirth, Aurebesh, Klingon, Sitelen Pona, Sadalian, etc.
- Inclut diverses écritures construites (conlang scripts)
- Certaines sont encore indiquées comme inachevées
Variantes japonaise et chinoise
- Une version unifont_jp prenant entièrement en charge la norme JIS X 0213 est proposée
- Elle utilisait d’abord Jiskan16, puis l’a remplacé par les glyphes libres Izumi16
- La version chinoise couvre intégralement le Tableau normatif général des caractères chinois d’usage courant
- Elle s’appuie sur les glyphes libres du projet Wen Quan Yi (文泉驛)
Détails techniques
- La conversion TrueType repose sur des scripts de Luis Alejandro González Miranda
- Automatisation de la conversion
.hex → .sfd → .ttf
- La base repose sur une grille de 16×16 pixels, avec une prise en charge future prévue pour des glyphes de 32×32 pixels
Feuille de route
- Tous les glyphes SMP en 16×16 pixels sont terminés
- Les écritures complexes comme le tangoute (Tangut) seront produites plus tard en 32×32 pixels
- L’ajout d’écritures CSUR se poursuit
- Toutes les nouvelles contributions doivent être publiées sous GPL 2+ / SIL OFL 1.1
Importance du projet
- GNU Unifont est une police libre majeure visant à garantir l’accessibilité numérique des systèmes d’écriture du monde entier
- Elle joue un rôle d’infrastructure clé dans l’écosystème open source, l’internationalisation (i18n) et l’ingénierie typographique
- C’est un projet qui améliore continuellement la complétude visuelle du standard Unicode grâce aux contributions de la communauté
Origine et structure du hangul
- Le hangul a été créé par le roi Sejong entre 1443 et 1446, puis promulgué en 1446 dans le Hunminjeongeum Haeryebon
- L’objectif déclaré de sa création était de permettre au peuple de “l’apprendre facilement et de l’utiliser commodément au quotidien”
- Le Haeryebon est un commentaire expliquant les principes de création, dont l’unique exemplaire redécouvert pendant la Seconde Guerre mondiale est conservé
- Le hangul repose sur une structure en blocs syllabiques composée de trois éléments : consonne initiale, voyelle médiane et consonne finale
- Exemple : “hangul” se compose des combinaisons ‘h + a + n’ et ‘g + eu + l’
- Les voyelles et semi-voyelles (y, w) sont placées à droite ou en dessous de la consonne initiale
Principe de composition des consonnes
- Les consonnes partent de cinq consonnes de base inspirées de la forme des organes de la parole (giyeok, nieun, mieum, siot, ieung)
- En y ajoutant des traits, les 17 consonnes originelles ont été formées
- Certaines consonnes utilisent des formes doublées pour marquer l’emphase
- Les jamo de compatibilité (Compatibility Jamo) sont aussi inclus dans Unicode, et certains jamo anciens ne sont plus utilisés aujourd’hui
Principe de composition des voyelles
- Les voyelles dérivent du concept des trois éléments cosmiques : ciel (yang), humain (milieu), terre (yin)
- Éléments de base : point (arae-a), ligne horizontale (eu), ligne verticale (i)
- Il existait à l’origine 11 voyelles, et arae-a a disparu du coréen standard moderne, mais subsiste dans le dialecte de Jeju
- La combinaison de voyelles forme des diphtongues, dont certaines ne sont plus utilisées en hangul moderne
- Le jeu de jamo hangul d’Unifont prend en charge toutes les voyelles et diphtongues, anciennes comme modernes
Zones hangul dans Unicode
- Le hangul figure dans les plages Unicode suivantes
- U+1100–U+11FF: Hangul Jamo
- U+3130–U+318F: Hangul Compatibility Jamo
- U+A960–U+A97F: Hangul Jamo Extended–A
- U+AC00–U+D7A3: Hangul Syllables
- U+D7B0–U+D7FF: Hangul Jamo Extended–B
- U+FFA0–U+FFDF: Half-width Compatibility Jamo
- L’ajustement de la position combinatoire des consonnes initiales, voyelles médianes et consonnes finales est au cœur du design typographique, et même une police bitmap peut représenter des syllabes combinatoires
Polices combinatoires (Johab) X11 et Unifont
- Les polices encodées en Johab génèrent des glyphes syllabiques en combinant consonne initiale, voyelle médiane et consonne finale
- Elles étaient utilisées dans le terminal Hanterm de l’environnement Unix X11
- Les polices libres pour Hanterm n’étant pas compatibles GPL, Unifont a donc créé directement de nouveaux glyphes syllabiques hangul
- Processus de conversion : script Perl johab2ucs2.pl → conversion
.hex → .bdf
- Les polices existantes (iyagi16, johabg16, etc.) étaient limitées par des licences réservées à Hanterm
- Un nouveau jeu de Hangul Syllables a ensuite été créé au fil des années puis intégré à Unifont
Contributions récentes et amélioration de l’encodage
- Minseo Lee : en 2023, a fourni des glyphes modernes basés sur l’ordre Hanterm ainsi que des versions corrigées de glyphes anciens
- Amélioration de scripts Perl et correction de la cohérence des jamo dans les plages Unicode
- Ho-Seok Ee : a proposé l’encodage Johab 6/3/1
- Avec une structure combinatoire de 6 initiales, 3 médianes et 1 finale, la génération des glyphes est simplifiée par rapport à l’ancien système
- Proposition de déplacer les points de code vers la Private Use Area (U+E000–U+E8FF)
- Cette méthode d’encodage a été adoptée à partir d’Unifont 15.1.01
Blocs syllabiques hangul Unicode (U+AC00–U+D7A3)
- Ils se composent au total de 11 172 glyphes syllabiques
- 19 consonnes initiales (ou 1 caractère de remplissage), 21 voyelles médianes, 27 consonnes finales (ou aucune)
- Formule combinatoire : (19×21)×28 = 11 172
- Les mots commençant par une voyelle utilisent la consonne initiale ‘ieung’ comme caractère de remplissage
- À partir d’Unifont 5.1, le nouveau processus de génération des blocs syllabiques est décrit en détail dans le document distinct Generating Hangul Syllables
Aucun commentaire pour le moment.