1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
//! ``` //! use glyph_brush::{ab_glyph::FontArc, BrushAction, BrushError, GlyphBrushBuilder, Section, Text}; //! //! # fn main() -> Result<(), Box<dyn std::error::Error>> { //! let dejavu = FontArc::try_from_slice(include_bytes!("../../fonts/DejaVuSans.ttf"))?; //! let mut glyph_brush = GlyphBrushBuilder::using_font(dejavu).build(); //! # let some_other_section = Section::default(); //! //! glyph_brush.queue(Section::default().add_text(Text::new("Hello glyph_brush"))); //! glyph_brush.queue(some_other_section); //! //! # fn update_texture(_: glyph_brush::Rectangle<u32>, _: &[u8]) {} //! # fn into_vertex(v: glyph_brush::GlyphVertex) { () } //! match glyph_brush.process_queued( //! |rect, tex_data| update_texture(rect, tex_data), //! |vertex_data| into_vertex(vertex_data), //! ) { //! Ok(BrushAction::Draw(vertices)) => { //! // Draw new vertices. //! } //! Ok(BrushAction::ReDraw) => { //! // Re-draw last frame's vertices unmodified. //! } //! Err(BrushError::TextureTooSmall { suggested }) => { //! // Enlarge texture + glyph_brush texture cache and retry. //! } //! } //! # Ok(()) //! # } //! ``` mod extra; mod glyph_brush; mod glyph_calculator; mod owned_section; mod section; pub mod legacy; pub use crate::{extra::*, glyph_brush::*, glyph_calculator::*, owned_section::*, section::*}; pub use glyph_brush_draw_cache::Rectangle; pub use glyph_brush_layout::*; use glyph_brush_layout::ab_glyph::*; /// A "practically collision free" `Section` hasher #[cfg(not(target_arch = "wasm32"))] pub type DefaultSectionHasher = twox_hash::RandomXxHashBuilder; // Work around for rand issues in wasm #61 #[cfg(target_arch = "wasm32")] pub type DefaultSectionHasher = std::hash::BuildHasherDefault<twox_hash::XxHash>; #[test] fn default_section_hasher() { use std::hash::{BuildHasher, Hash, Hasher}; let section_a = Section::default().add_text(Text::new("Hovered Tile: Some((0, 0))")); let section_b = Section::default().add_text(Text::new("Hovered Tile: Some((1, 0))")); let hash = |s: &Section| { let mut hasher = DefaultSectionHasher::default().build_hasher(); s.hash(&mut hasher); hasher.finish() }; assert_ne!(hash(§ion_a), hash(§ion_b)); }