使用 Opentype.js 生成字體子集的實(shí)例代碼詳解
字體子集是將字體文件中部分多余的字符刪除,來(lái)減小文件大小,從而在 Web 端使用或嵌入到其他應(yīng)用或系統(tǒng)中,在網(wǎng)上可以找到不少這方面的工具。
Opentype.js是一套可以支持瀏覽器環(huán)境和 Node.js 環(huán)境的開(kāi)源 OpenType 字體讀寫(xiě)庫(kù),利用這個(gè)庫(kù)可以很輕松實(shí)現(xiàn)瀏覽器環(huán)境和 Node.js 環(huán)境的字體子集功能。
在瀏覽器環(huán)境創(chuàng)建字體子集工具
首先創(chuàng)建一個(gè)簡(jiǎn)單的 HTML界面,包括一個(gè)選取字體文件按鈕,一個(gè)輸入框用于輸入保留的字符,和一個(gè)保存下載按鈕。
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)建項(xiàng)目文件
在 Node.js 版的項(xiàng)目中,可以考慮通過(guò)配置文件來(lái)實(shí)現(xiàn)批量處理多個(gè)字體文件功能。
mkdir font_subset cd font_subset npm init
項(xiàng)目結(jié)構(gòu)如下,把所有原始的字體保存在 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ù)組類型,可配置多個(gè)字體文件;texts
字符串類型,輸入需要保留的字符,字符可以重復(fù),可包含空格,不可換行,英文雙引號(hào)使用\"
表示。
{ "fonts": ["./src/NotoSerifSC-Bold.otf"], "texts": " 0123456789:" }
生成字體
main.js 內(nèi)容如下。
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); });
打開(kāi)終端項(xiàng)目所在目錄,輸入以下命令,字體保存到 “dist” 文件夾下。
node main.js
總結(jié)
到此這篇關(guān)于使用 Opentype.js 生成字體子集的實(shí)例代碼詳解的文章就介紹到這了,更多相關(guān)Opentype.js 字體子集內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS關(guān)閉窗口與JS關(guān)閉頁(yè)面的幾種方法小結(jié)
本篇文章要是對(duì)JS關(guān)閉窗口與JS關(guān)閉頁(yè)面的幾種方法進(jìn)行了總結(jié)介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-12-12JS利用時(shí)間戳倒計(jì)時(shí)的實(shí)現(xiàn)示例
這篇文章主要介紹了JS利用時(shí)間戳倒計(jì)時(shí)的實(shí)現(xiàn)示例,本文將提供代碼示例和詳細(xì)的步驟,幫助你實(shí)現(xiàn)一個(gè)簡(jiǎn)單而實(shí)用的時(shí)間戳倒計(jì)時(shí),感興趣的可以了解一下2023-12-12JavaScript 設(shè)計(jì)模式 富有表現(xiàn)力的Javascript(一)
javascript設(shè)計(jì)模式是圖靈出版,學(xué)習(xí)中力求每個(gè)章節(jié)都細(xì)看。2010-05-05JavaScript實(shí)現(xiàn)經(jīng)典排序算法之冒泡排序
這篇文章主要介紹了JavaScript實(shí)現(xiàn)經(jīng)典排序算法之冒泡排序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12selenium+java中用js來(lái)完成日期的修改
這篇文章主要介紹了selenium+java中用js來(lái)完成日期的修改,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10