1.0.3 • Published 6 months ago

woff2-encoder v1.0.3

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

woff2-encoder

A TypeScript library for handling WOFF2 encoding using WebAssembly.


🚀 Getting Started

Prerequisites

  • If using Node, >= 16.x

Installation

npm install woff2-encoder

📚 API Reference

compress

Compresses SFNT (TrueType/OpenType) font data to WOFF2 font data.

Returns: Promise<Uint8Array> A promise resolving to the WOFF2 font data.

ParameterTypeDescription
bufferArrayBuffer \| Uint8ArrayThe SFNT font data.

decompress

Decompresses WOFF2 font data back to SFNT (TrueType/OpenType) font data.

Returns: Promise<Uint8Array> A promise resolving to the SFNT font data.

ParameterTypeDescription
bufferArrayBuffer \| Uint8ArrayThe WOFF2 font data.

💡 Examples

Compress a TTF font using Node.js

import fs from 'node:fs';
import { compress } from 'woff2-encoder';

async function example() {
  const fontFile = fs.readFileSync('./myFont.ttf');
  const output = await compress(fontFile);
}

Decompress a WOFF2 font from a URL

import { decompress } from 'woff2-encoder';

async function example() {
  const fontBuffer = await fetch('https://example.com/myFont.woff2').then(
    (res) => res.arrayBuffer()
  );

  const output = await decompress(fontBuffer);
}

Parse a WOFF2 font with opentype.js

import fs from 'node:fs';
import opentype from 'opentype.js';
import { decompress } from 'woff2-encoder';

async function example() {
  const fontFile = fs.readFileSync('./myFont.woff2');
  const output = await decompress(fontFile);

  // Since opentype.js requires a buffer, we pass
  // in the buffer and not the byte array itself
  const fontData = opentype.parse(output.buffer);
}

⭐ Acknowledgements

  • google/woff2 - For the C++ implemention for encoding WOFF2 files.
  • fontello/wawoff2 - For the initial WebAssembly port of Google's WOFF2 encoder.

📃 License

MIT License. See LICENSE for details.

1.0.3

6 months ago

1.0.2

7 months ago

1.0.1

7 months ago

1.0.0

8 months ago