Skip to content

Latest commit

 

History

History
91 lines (58 loc) · 5.41 KB

README.md

File metadata and controls

91 lines (58 loc) · 5.41 KB

RenderStack

Try RenderStack now

RenderStack is a web app that renders a font using multiple renderers. It’s useful for finding visual differences in rendering and layout. It also demonstrates how to make each renderer work on the web. Its font menu links to several open-source fonts, and it also allows drag & drop. Samsa, Fontkit and Harfbuzz are currently supported. Their renderings appear alongside the browser’s own rendering.

User guide

  • Select a font, or upload a font (font data does not leave the browser’s memory).
  • Adjust variation axes.
  • Type some text.
  • Adjust font size.
  • Adjust foreground colour (not yet).
  • Inspect the renderings!
  • Download the renderings to inspect them in more detail (not yet).

The project seeks to add additional renderers. If your favourite renderer can be built in JavaScript or WASM, then it is welcome to be added to RenderStack. A FreeType renderer would be particularly welcome.

Running RenderStack on your own server

The repo includes a ready-to-run version of RenderStack in the dist folder. To run it on your own server:

  1. Clone this GitHub repository.
  2. Place the contents of the dist folder somewhere on your server.
  3. With a browser, visit the dist folder on your server.

Building RenderStack

To develop RenderStack, or even to edit the default list of fonts, you will need to build it. We use Parcel to bundle all the code into a single file, and the following instructions assume this:

  1. Install node and npm.
  2. Install Parcel.
  3. Clone this GitHub repository.
  4. cd to the project folder.
  5. Run npm install to install dependencies.
  6. Run npm run build to build the project.

Notes:

  • Samsa and Harfbuzz.js are not currently available via npm, so they are included already in node_modules
  • Parcel uses SWC to minify the code
  • The command npm run build runs the build script in package.json. This copies the fonts folder and hb.wasm from src to dist, and runs Parcel.

Renderer comparisons

Renderer kB Variations OTL COLRv0 COLRv1 avar2
Safari
Chrome (macOS)
Chrome (Windows)
Samsa 46¹
Fontkit 353¹
Harfbuzz 355² ✗³

¹ measured after minification by SWC
² this is the size of hb.wasm, compiled with support for avar2 and COLRv1
³ although Harfbuzz parses the COLRv1 paint tables, JS bindings for hbjs.js have yet to be written

Implementation notes

Samsa

Uses Samsa Core v2, a major update on Samsa Core v1. Samsa Core v2 includes handling for:

  • avar version 2
  • COLRv1 (partial)
  • basic layout

When it’s ready, Samsa Core will be made available via npm.

Fontkit

Fontkit is an advanced font engine for Node and the browser, used by PDFKit. It supports many font formats, advanced glyph substitution and layout features, glyph path extraction, color emoji glyphs, font subsetting, and more.

— From the Fontkit GitHub repo

Harfbuzz

HarfBuzz is a text-shaping engine. If you give HarfBuzz a font and a string containing a sequence of Unicode codepoints, HarfBuzz selects and positions the corresponding glyphs from the font, applying all of the necessary layout rules and font features. HarfBuzz then returns the string to you in the form that is correctly arranged for the language and writing system. HarfBuzz can properly shape all of the world's major writing systems. It runs on all major operating systems and software platforms and it supports the major font formats in use today.

— From What is Harfbuzz?

Harfbuzz is able to work on the web thanks to Harfbuzz.js. This provides a WebAssembly binary, hb.wasm and a JavaScript wrapper, hbjs.js. The JS file is bundled into the RenderStack code, and the Wasm file is copied to the dist folder during the build process.

Note that Harfbuzz is not primarily designed for font rendering, but offers SVG-compatible primitives so that glyphs can be displayed as well as laid out. More commonly, Harfbuzz is used by a text library to transform a string of text into a set of glyph IDs and positions, where a renderer such as FreeType generates the glyph images, and the text library positions them using the glyph positions provided by Harfbuzz.

Building hb.wasm

You may want to update the WebAssembly version of Harfbuzz, for example to try variable components or other optional features. To do this, clone the Harfbuzz.js and Harfbuzz repos, tune Harfbuzz compiler flags, and build a new hb.wasm using the build.sh script.