Crate glyph_brush_layout
source ·Expand description
Text layout for ab_glyph.
§Example
use glyph_brush_layout::{ab_glyph::*, *};
let dejavu = FontRef::try_from_slice(include_bytes!("../../fonts/DejaVuSans.ttf"))?;
let garamond = FontRef::try_from_slice(include_bytes!("../../fonts/GaramondNo8-Reg.ttf"))?;
// Simple font mapping: FontId(0) -> deja vu sans, FontId(1) -> garamond
let fonts = &[dejavu, garamond];
// Layout "hello glyph_brush_layout" on an unbounded line with the second
// word suitably bigger, greener and serif-ier.
let glyphs = Layout::default().calculate_glyphs(
    fonts,
    &SectionGeometry {
        screen_position: (150.0, 50.0),
        ..SectionGeometry::default()
    },
    &[
        SectionText {
            text: "hello ",
            scale: PxScale::from(20.0),
            font_id: FontId(0),
        },
        SectionText {
            text: "glyph_brush_layout",
            scale: PxScale::from(25.0),
            font_id: FontId(1),
        },
    ],
);
assert_eq!(glyphs.len(), 24);
let SectionGlyph {
    glyph,
    font_id,
    section_index,
    byte_index,
} = &glyphs[4];
assert_eq!(glyph.id, fonts[0].glyph_id('o'));
assert_eq!(*font_id, FontId(0));
assert_eq!(*section_index, 0);
assert_eq!(*byte_index, 4);
let SectionGlyph {
    glyph,
    font_id,
    section_index,
    byte_index,
} = &glyphs[14];
assert_eq!(glyph.id, fonts[1].glyph_id('u'));
assert_eq!(*font_id, FontId(1));
assert_eq!(*section_index, 1);
assert_eq!(*byte_index, 8);
Modules§
- Re-exported ab_glyph types.
Structs§
- Id for a font.
- A positioned glyph with info relating to theSectionText(or glyph_brushSection::text) from which it was derived.
- Text to layout together using a font & scale.
Enums§
- Built-in linebreaking logic.
- Describes horizontal alignment preference for positioning & bounds.
- Built-inGlyphPositionerimplementations.
- Indicator that a character is a line break, soft or hard. Includes the offset (byte-index) position.
- Describes vertical alignment preference for positioning & bounds. Currently a placeholder for future functionality.