7 releases

0.1.6 Jun 22, 2024
0.1.5 Nov 13, 2021
0.1.4 Jan 21, 2021
0.1.3 Oct 17, 2020
0.1.0 May 23, 2020

#54 in Caching

Download history 2371/week @ 2024-10-18 2576/week @ 2024-10-25 2512/week @ 2024-11-01 1676/week @ 2024-11-08 2022/week @ 2024-11-15 2465/week @ 2024-11-22 2760/week @ 2024-11-29 2801/week @ 2024-12-06 3391/week @ 2024-12-13 1869/week @ 2024-12-20 1446/week @ 2024-12-27 2439/week @ 2025-01-03 4219/week @ 2025-01-10 3373/week @ 2025-01-17 2688/week @ 2025-01-24 4180/week @ 2025-01-31

14,735 downloads per month
Used in 116 crates (via glyph_brush)

Apache-2.0

65KB
890 lines

glyph_brush_draw_cache crates.io Documentation

Rasterization cache for ab_glyph used in glyph_brush.

  • Manages a texture. Draws glyphs into it and provides texture rect lookup for glyphs.
  • Automatic re-use & reordering when needed.
use glyph_brush_draw_cache::DrawCache;

// build a cache with default settings
let mut draw_cache = DrawCache::builder().build();

// queue up some glyphs to store in the cache
for (font_id, glyph) in glyphs {
    draw_cache.queue_glyph(font_id, glyph);
}

// process everything in the queue, rasterizing & uploading as necessary
draw_cache.cache_queued(&fonts, |rect, tex_data| update_texture(rect, tex_data))?;

// access a given glyph's texture position & pixel position for the texture quad
match draw_cache.rect_for(font_id, &glyph) {
    Some((tex_coords, px_coords)) => {}
    None => {/* The glyph has no outline, or wasn't queued up to be cached */}
}

Example

See the draw_cache_guts example to see how it works (run it from the top level).

cargo run --example draw_cache_guts

Dependencies

~1.5MB
~28K SLoC