使用 Opentype.js 生成字體子集的實例代碼詳解
字體子集是將字體文件中部分多余的字符刪除,來減小文件大小,從而在 Web 端使用或嵌入到其他應用或系統(tǒng)中,在網(wǎng)上可以找到不少這方面的工具。
Opentype.js是一套可以支持瀏覽器環(huán)境和 Node.js 環(huán)境的開源 OpenType 字體讀寫庫,利用這個庫可以很輕松實現(xiàn)瀏覽器環(huán)境和 Node.js 環(huán)境的字體子集功能。
在瀏覽器環(huán)境創(chuàng)建字體子集工具
首先創(chuàng)建一個簡單的 HTML界面,包括一個選取字體文件按鈕,一個輸入框用于輸入保留的字符,和一個保存下載按鈕。
HTML
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Font Subset</title> </head> <body> <div> <p><label for="text">Choose a font file:</label></p> <input type="file" id="file"> </div> <div> <p><label for="text">Text:</label></p> <textarea id="text"></textarea> </div> <div> <input type="button" id="save" value="save"> </div> </body> </html>
在 HTML 的</body>前引入 opentype.js,并加入 Javascript。
<script src="https://cdn.jsdelivr.net/npm/opentype.js@latest/dist/opentype.min.js"></script>
<script>
var save = document.getElementById("save");
save.onclick = function() {
var file = document.getElementById("file");
var text = document.getElementById("text");
if (file.files.length === 0) {
alert("Choose a font file.")
return;
}
if (text.value === "") {
alert("Type some text.")
return;
}
var glyphsArray = text.value.split("");
var glyphs = glyphsArray.filter(function(item) {
return item !== " ";
}).filter(function(item, index) {
return glyphsArray.indexOf(item) === index;
}).join("");
var reader = new FileReader();
reader.onload = function(error) {
try {
var font = opentype.parse(reader.result);
var postScriptName = font.getEnglishName("postScriptName");
var [familyName, styleName] = postScriptName.split("-");
var notdefGlyph = font.glyphs.get(0);
notdefGlyph.name = ".notdef";
var subGlyphs = [notdefGlyph].concat(font.stringToGlyphs(glyphs));
var subsetFont = new opentype.Font({
familyName: familyName,
styleName: styleName,
unitsPerEm: font.unitsPerEm,
ascender: font.ascender,
descender: font.descender,
designer: font.getEnglishName("designer"),
designerURL: font.getEnglishName("designerURL"),
manufacturer: font.getEnglishName("manufacturer"),
manufacturerURL: font.getEnglishName("manufacturerURL"),
license: font.getEnglishName("license"),
licenseURL: font.getEnglishName("licenseURL"),
version: font.getEnglishName("version"),
description: font.getEnglishName("description"),
copyright: "This is a subset font of " + postScriptName + ". " + font.getEnglishName("copyright"),
trademark: font.getEnglishName("trademark"),
glyphs: subGlyphs
});
subsetFont.download();
} catch (error) {
alert(error.message);
throw(error);
}
};
reader.onerror = function(error) {
alert(error.message);
throw(error);
};
reader.readAsArrayBuffer(file.files[0]);
};
</script>
在 Node.js 環(huán)境創(chuàng)建字體子集工具
創(chuàng)建項目文件
在 Node.js 版的項目中,可以考慮通過配置文件來實現(xiàn)批量處理多個字體文件功能。
mkdir font_subset cd font_subset npm init
項目結構如下,把所有原始的字體保存在 src 目錄下,子集化之后的字體保存在 dist 目錄下,main.js 為主腳本。
font_subset ├── config.json ├── dist ├── main.js ├── node_modules ├── package-lock.json ├── package.json └── src └── NotoSerifSC-Bold.otf
字體配置
修改 “config.json” 文件。fonts數(shù)組類型,可配置多個字體文件;texts字符串類型,輸入需要保留的字符,字符可以重復,可包含空格,不可換行,英文雙引號使用\"表示。
{
"fonts": ["./src/NotoSerifSC-Bold.otf"],
"texts": " 0123456789:"
}
生成字體
main.js 內容如下。
const config = require('./config.json');
const fonts = config.fonts;
const texts = config.texts;
const path = require('path');
const opentype = require('opentype.js');
const glyphs = [...new Set(texts.split(''))].join('');
fonts.forEach(item => {
const font = opentype.loadSync(item);
const postScriptName = font.getEnglishName('postScriptName');
const dist = path.join(
'dist',
postScriptName.replace(/-/g, '_').toLowerCase() + '_subset.otf'
);
const [familyName, styleName] = postScriptName.split('-');
const notdefGlyph = font.glyphs.get(0);
notdefGlyph.name = '.notdef';
const subGlyphs = [notdefGlyph].concat(font.stringToGlyphs(glyphs));
const subsetFont = new opentype.Font({
familyName: familyName,
styleName: styleName,
unitsPerEm: font.unitsPerEm,
ascender: font.ascender,
descender: font.descender,
designer: font.getEnglishName('designer'),
designerURL: font.getEnglishName('designerURL'),
manufacturer: font.getEnglishName('manufacturer'),
manufacturerURL: font.getEnglishName('manufacturerURL'),
license: font.getEnglishName('license'),
licenseURL: font.getEnglishName('licenseURL'),
version: font.getEnglishName('version'),
description: font.getEnglishName('description'),
copyright: 'This is a subset font of ' + postScriptName + '. ' + font.getEnglishName('copyright'),
trademark: font.getEnglishName('trademark'),
glyphs: subGlyphs
});
subsetFont.download(dist);
});
打開終端項目所在目錄,輸入以下命令,字體保存到 “dist” 文件夾下。
node main.js
總結
到此這篇關于使用 Opentype.js 生成字體子集的實例代碼詳解的文章就介紹到這了,更多相關Opentype.js 字體子集內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript 設計模式 富有表現(xiàn)力的Javascript(一)
javascript設計模式是圖靈出版,學習中力求每個章節(jié)都細看。2010-05-05
JavaScript實現(xiàn)經(jīng)典排序算法之冒泡排序
這篇文章主要介紹了JavaScript實現(xiàn)經(jīng)典排序算法之冒泡排序,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12

