harfbuzzjs
v1.2.0
Published
Minimal version of HarfBuzz for JavaScript use
Downloads
279,242
Readme
harfbuzzjs
Providing HarfBuzz shaping library for client/server side JavaScript projects.
See the demo here.
Building
- Install emscripten
make
Testing
make test
Download
Download from the releases tab.
Migrating from v0.x
The v1 release introduced several API-breaking changes. See MIGRATING for migrating from v0.x.
Usage
TL;DR
import * as hb from "harfbuzzjs";
const fontdata = await fetch('myfont.ttf').then(r => r.arrayBuffer());
const blob = new hb.Blob(fontdata); // Load the font data into Harfbuzz blob
const face = new hb.Face(blob, 0); // Select the first font in the file
const font = new hb.Font(face); // Create a Harfbuzz font object from the face
const buffer = new hb.Buffer(); // Make a buffer to hold some text
buffer.addText('abc'); // Fill it with some stuff
buffer.guessSegmentProperties(); // Set script, language and direction
hb.shape(font, buffer); // Shape the text
const output = buffer.getGlyphInfosAndPositions();
// Enumerate the glyphs
var xCursor = 0;
var yCursor = 0;
for (var glyph of output) {
var glyphId = glyph.codepoint;
var xAdvance = glyph.xAdvance;
var yAdvance = glyph.yAdvance;
var xDisplacement = glyph.xOffset;
var yDisplacement = glyph.yOffset;
var svgPath = font.glyphToPath(glyphId);
// You need to supply this bit
drawAGlyph(svgPath, xCursor + xDisplacement, yCursor + yDisplacement);
xCursor += xAdvance;
yCursor += yAdvance;
}More examples:
Browser
npx pad.js- Open
http://127.0.0.1/examples/harfbuzz.example.html
Node.js
node examples/harfbuzz.example.node.js
npm
Can be added with npm i harfbuzzjs or yarn add harfbuzzjs, see the examples for
how to use it.
Need more of the library?
harfbuzzjs uses a stripped-down version of Harfbuzz generated by compiling Harfbuzz with -DHB_TINY. This may mean that some functions you need are not available. Look at src/harfbuzz-config.hh in the Harfbuzz source directory to see what has been removed. For example, HB_TINY defines HB_LEAN which (amongst other things) defines HB_NO_OT_GLYPH_NAMES. If, for example, you really need to get at the glyph names:
- First, undefine the macro in question, by adding e.g.
#undef HB_NO_OT_GLYPH_NAMEStoconfig-override.h. - Next, export any function that you need by adding a line to
harfbuzz.symbols; in this case_hb_ot_get_glyph_name. - Now the function will be exported through the WASM object, but you need to add TypeScript to bridge to it - in this case, handling the memory allocation of the
char *parameternameand marshalling it to a JavaScript string. The best way to do this is to look at the source files insrc/for functions which use similar signatures.
If you have extended harfbuzzjs in ways that you think others will also benefit from, please raise a pull request. If there are parts of Harfbuzz that you need but the instructions above don't work, describe what you are trying to do in an issue.
Using the library in a bigger emscripten project?
See harfbuzz port inside emscripten
and emscripten-ports/HarfBuzz, basically all you need is to use
-s USE_HARFBUZZ=1 in your build.
binaryen
Optionally you can install binaryen and use wasm-opt like:
wasm-opt -Oz harfbuzz.wasm -o harfbuzz.wasmbinaryen also provides wasm-dis which can be used for,
wasm-dis harfbuzz.wasm | grep export
wasm-dis harfbuzz.wasm | grep importwith that you can check if the built wasm file only exports things you need and doesn't need to import anything, as usual with wasm files built here.
