egui_nerdfonts
1.0.0
Bundles Icônes de polices nerd pour egui.
Ajoutez la caisse en tant que dépendance en cargo.toml:
egui_nerdfonts = " 0.1.3 " ou tapez cargo add egui_nerdfonts , dans votre projet.
Tout d'abord, mettez à jour les polices dans votre contexte EGUI:
let mut fonts = egui :: FontDefinitions :: default ( ) ;
egui_nerdfonts :: add_to_fonts ( & mut fonts , egui_nerdfonts :: Variant :: Regular ) ;
let egui_ctx = Context :: default ( ) ;
egui_ctx . set_fonts ( fonts ) ;Choisissez les icônes Nerdfonts que vous souhaitez utiliser parmi celles-ci.
Utilisez ensuite les icônes Nerdfonts comme suit:
ui . label ( format ! ( "{}" , egui_nerdfonts :: regular :: NF_DEV_RUST ) ) ; cargo run --example rust_logo

Inspiré par EGui_phosphor, le code utilise la même structure.
Le .TTF utilisé est celui-ci, et le src/variants/regular.rs a été généré avec le script Python suivant, avec le nerdfonts_regular.ttf comme premier argument:
from itertools import chain
from fontTools . ttLib import TTFont
from fontTools . unicode import Unicode
import sys
with TTFont (
sys . argv [ 1 ], 0 , allowVID = 0 , ignoreDecompileErrors = True , fontNumber = - 1
) as ttf :
chars = chain . from_iterable (
[ y + ( Unicode [ y [ 0 ]],) for y in x . cmap . items ()] for x in ttf [ "cmap" ]. tables
)
for char in chars :
symbol_name = char [ 1 ]. upper (). replace ( '-' , '_' ). replace ( ' ' , '_' ). replace ( '#' , '_' ). replace ( '!' , '' )
code = r"u" + "{" + f" { char [ 0 ]:X } " + "}"
print ( f"pub const { symbol_name } : &str = " { code } " ;" )