font-carrier
font-carrier 是一个功能强大的字体操作库,使用它你可以随心所欲地操作字体。
一个字体 font,包含若干字形 glyph。比如我们浏览器里渲染我
,浏览器就会去当前设置的font里面找到 我
对应的字形 glyph,使用它的形状来渲染。不同的字体的我
的字形形状不一,所以才有差别。
font-carrier 封装了简单的 API,让你可以将某个 SVG,设置成一个字对应的字形。也可以通过解析已有字体,拿到某个字在这个字体下面对应的 SVG。让你通过 SVG 的维度随意修改字体展现样式。
我们不生产字体,我们只是字体的搬运工
Features
- 支持创建一个空白字体
- 支持解析已有字体(ttf,SVG)
- 支持使用 SVG 来设置字的展现
- 支持解析 SVG 的各种转换还有各种非 path 图形
- 支持针对某一个字,导出对应的 SVG
- 支持导出5种浏览器主流字体(ttf,eot,woff,woff2,svg)
- 支持设置各种字体相关内容
Getting Start
如果对 iconfont 还不是很了解的,请先参考这篇文章
Install
npm install font-carrier --save
Usage
Step-1:创建一个空白字体,或者解析一个已有的字体,这样都可以得到一个字体对象
var fontCarrier = require('font-carrier')
var font = fontCarrier.create()
var transFont = fontCarrier.transfer('./test/test.ttf')
Step-2:拿到字体对象后,你就可以使用 SVG 随意操作字体了
font.setSvg('我', fs.readFileSync('./test/svgs/circle.svg').toString())
font.setGlyph('我', {
glyphName: '我',
horizAdvX: '1024',
svg:fs.readFileSync('./test/svgs/circle.svg').toString()
})
var svg = font.getSvg('我')
var glyph = transFont.getGlyph('我')
glyph.toSvg()
Step-3:使用get,set各种操作完后,你可以选择导出字体
font.output({
path: './iconfont'
})
Step-4:导出字体后就可以在 Web 中使用了
<style type="text/css">
@font-face {
font-family: 'iconfont';
src: url('iconfont.eot');
src: url('iconfont.eot?#iefix') format('embedded-opentype'),
url('iconfont.woff') format('woff2'),
url('iconfont.woff') format('woff'),
url('iconfont.ttf') format('truetype'),
url('iconfont.svg#iconfont') format('svg');
}
.iconfont {
font-family: "iconfont";
font-size: 16px;
font-style: normal;
}
</style>
<span class="iconfont">我</span>
//此时渲染出来的图形就是你设置的 SVG的样子
Example
案例一
使用 SVG 设置一些 icon
var fontCarrier = require('font-carrier')
var font = fontCarrier.create()
var love = fs.readFileSync('./test/svgs/love.svg').toString()
var mail = fs.readFileSync('./test/svgs/mail.svg').toString()
font.setGlyph('爱', {
svg: love,
glyphName: '爱'
})
font.setSvg('', mail)
font.output({
path: './test'
})
案例二
从其他字体导出一些图标到自己的库里
var fontCarrier = require('font-carrier')
var transFont = fontCarrier.transfer('./test/test.ttf')
var font = fontCarrier.create()
var gs = transFont.getGlyph('我是方正')
font.setGlyph(gs)
/ /这样 font 导出的字体里面就有了「我是方正」对应的 SVG 形状了
font.output({
path: './test'
})
案例三
对中文字体精简
var fontCarrier = require('font-carrier')
var transFont = fontCarrier.transfer('./test/test.ttf')
transFont.min('我是精简后的字体,我可以重复')
transFont.output({
path: './min'
})
API
更多文档请看这里
Test
先确保安装依赖包 npm install
再运行npm test
之后访问 ./test/index.html
MIT