egui_nerdfonts
1.0.0
Bundles Nerd Fonts Icons para EGUI.
Agregue la caja como dependencia en CARGO.TOML:
egui_nerdfonts = " 0.1.3 " O escriba cargo add egui_nerdfonts , en su proyecto.
Primero, actualice las fuentes en su contexto 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 ) ;Elija los iconos NerdFonts que desea usar entre estos.
Luego use iconos NerdFonts de la siguiente manera:
ui . label ( format ! ( "{}" , egui_nerdfonts :: regular :: NF_DEV_RUST ) ) ; cargo run --example rust_logo

Se inspiró en EGUI_PHOSFOR, el código usa la misma estructura.
El .ttf utilizado es este, y el src/variants/regular.rs se generó con el siguiente script de Python, con el nerdfonts_regular.ttf como primer argumento:
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 } " ;" )