如何使用Opentype.js生成字体子集-乐山大橙子建站
选择下列产品马上在线沟通
服务时间:8:30-17:00
这篇文章主要讲解了如何使用Opentype.js生成字体子集,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都网站制作、成都做网站、河西网络推广、微信平台小程序开发、河西网络营销、河西企业策划、河西品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供河西建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
字体子集是将字体文件中部分多余的字符删除,来减小文件大小,从而在 Web 端使用或嵌入到其他应用或系统中,在网上可以找到不少这方面的工具。
Opentype.js是一套可以支持浏览器环境和 Node.js 环境的开源 OpenType 字体读写库,利用这个库可以很轻松实现浏览器环境和 Node.js 环境的字体子集功能。
在浏览器环境创建字体子集工具
首先创建一个简单的 HTML界面,包括一个选取字体文件按钮,一个输入框用于输入保留的字符,和一个保存下载按钮。
HTML
在 HTML 的
前引入 opentype.js,并加入 Javascript。
在 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
看完上述内容,是不是对如何使用Opentype.js生成字体子集有进一步的了解,如果还想学习更多内容,欢迎关注创新互联行业资讯频道。
新闻名称:如何使用Opentype.js生成字体子集
网页URL:http://lswzjz.com/article/gsedoc.html