egui_nerdfonts
1.0.0
Pacotes de ícones de fontes nerd para egui.
Adicione a caixa como uma dependência em carga.toml:
egui_nerdfonts = " 0.1.3 " ou tipo cargo add egui_nerdfonts , em seu projeto.
Primeiro, atualize as fontes em seu 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 ) ;Escolha os ícones NerdFonts que você deseja usar entre eles.
Em seguida, use ícones NerdFonts da seguinte maneira:
ui . label ( format ! ( "{}" , egui_nerdfonts :: regular :: NF_DEV_RUST ) ) ; cargo run --example rust_logo

Inspirado no egui_phosphor, o código usa a mesma estrutura.
O .ttf usado é este, e o src/variants/regular.rs foi gerado com o seguinte script Python, com o nerdfonts_regular.ttf como primeiro 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 } " ;" )