字体子集是将字体文件中部分多余的字符删除,来减小文件大小,从而在 Web 端使用或嵌入到其他应用或系统中,在网上可以找到不少这方面的工具。
Opentype.js是一套可以支持浏览器环境和 Node.js 环境的开源 OpenType 字体读写库,利用这个库可以很轻松实现浏览器环境和 Node.js 环境的字体子集功能。
在浏览器环境创建字体子集工具
首先创建一个简单的 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="/UploadFiles/2021-04-02/opentype.min.js">在 Node.js 环境创建字体子集工具
创建项目文件
在 Node.js 版的项目中,可以考虑通过配置文件来实现批量处理多个字体文件功能。
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
数组类型,可配置多个字体文件;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
总结
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】
- 邓丽欣.2006-FANTASY【金牌大风】【WAV+CUE】
- 饭制《黑神话》蜘蛛四妹手办
- 《燕云十六声》回应跑路:年内公测版本完成95%
- 网友发现国内版《双城之战》第二季有删减:亲亲环节没了!
- 邓丽君2024-《漫步人生路》头版限量编号MQA-UHQCD[WAV+CUE]
- SergeProkofievplaysProkofiev[Dutton][FLAC+CUE]
- 永恒英文金曲精选4《TheBestOfEverlastingFavouritesVol.4》[WAV+CUE]
- 群星《国风超有戏 第9期》[320K/MP3][13.63MB]
- 群星《国风超有戏 第9期》[FLAC/分轨][72.56MB]