Skip to content

A port & overhaul of Vertex Engine GPU Font Cache for the Odin programming language

License

Notifications You must be signed in to change notification settings

Ed94/VEFontCache-Odin

Repository files navigation

VE Font Cache

Vertex Engine GPU Font Cache: A text rendering library.

This project started as a port of the VEFontCache library to the Odin programming language.
While originally intended for game engines, its rendering quality and performance make it suitable for many other applications.

Since then, the library has been overhauled to offer higher performance, improved visual fidelity, additional features, and quality of life improvements.

Features:

  • Simple and well documented
  • Load and unload fonts at any time
  • Almost entirely configurable and tunable at runtime
  • Full support for hot-reload
    • Clear the caches at any time
  • Robust quality of life features:
    • Snap positioning to view for better hinting
    • Tracks text layers
    • Enforce even-only font sizing (useful for linear zoom)
    • Push and pop stack for font, font_size, color, view, position, scale, and zoom
  • Basic or advanced text shaping via Harfbuzz
  • All rendering is real-time, with triangulation on the CPU, vertex rendering and texture blitting on the GPU
    • Can handle thousands of draw text calls with very large or small shapes
  • 4-Level Regioned Texture Atlas for caching rendered glyphs
  • Text shape caching
  • Glyph texture buffer for rendering text with super-sampling to downsample to the atlas or direct to target screen
  • Super-sample by a font size scalar for sharper glyphs
  • All caching backed by an optimized 32-bit LRU indexing cache
  • Provides a backend-agnostic draw list (see backend for usage example)

Upcoming:

  • Support choosing between top-left or bottom-left coordinate convention (currently bottom-left)
  • Support for better triangulation
    • Support for triangulation method selection on a per-font basis
    • Reference paper
  • Better support for tuning glyph render sampling
    • Support for sub-pixel AA
    • Ability to decide AA method & degree on a per-font basis
  • Multi-threading supported job queue
    • Lift heavy-lifting portion of the library's context into a thread context
    • Synchronize threads by merging their generated layered draw list into a finished draw list for processing on the user's render thread
    • User defines how thread contexts are distributed for drawing (a basic quadrant-based selector procedure will be provided)

Documentation

Building

See scripts/Readme.md for building examples or utilizing the provided backends.

Currently, the scripts provided & the library itself were developed & tested on Windows. There are bash scripts for building on Linux (they build on WSL but need additional testing).

The library depends on harfbuzz & stb_truetype to build.
Note: harfbuzz could technically be removed if the user removes their definitions, however this hasn't been made into a conditional compilation option yet.

Gallery

sokol_demo_2025-01-11_01-32-24

2025-01-11.01-33-37.mp4
2025-01-11.01-35-10.mp4
2025-01-11.01-24-39.mp4