一、了解彩色字体
所谓彩色字体,指的是那些内部自带彩色字形的字体,例如 Adobe 出品的 Gilbert 字体。
我猜有些人可能会有这样的想法:喔噢,好酷好厉害,浏览器什么时候支持啊?
结果一定让大家大吃一惊!
彩色字体实际上浏览器很早就支持了,如果当前字体采用的是 COLR/CPAL(v0) 标准制作的,则包括 IE9(需要 Windows 8.1+) 在内的浏览器均是支持的。
其兼容性如下图所示。
目前彩色字体的标准有四个,COLR/CPAL标准是其中之一,各个标准和兼容性见下表(源自我两年前就研究并介绍过的文章 -- "关于CSS emoji字体和OpenType-SVG我所知道的一些事"):
|---|--------|--------|------|---------| | | Chrome | Safari | Edge | Firefox |
其中,虽然有很多字体采用SVG-in-Opentype这个标准,但是 Chrome 明确将其他人提交的"支持 SVG Opentype bug"标记为"不会修复",因此可以预期,再很长一段时间,甚至是永远,Chrome 并不会支持SVG-in-Opentype标准。
而至于SBIX 和 CBDT/CBLC 标准虽然 Chrome 浏览器支持,但是此标准下实现的字体体积太大了,不太适合用在 Web 中,因此,几乎可以确认,未来在 Web 领域,脱颖而出的标准一定是 COLR/CPAL 标准。
COLR/CPAL(v1) 标准
目前的 COLR 标准已经是 v1 版本,属于 OpenType 1.9 标准的一部分。
相比 v0 版本,v1 版本要强大的多,不仅支持纯色,还支持各种渐变(线性、径向和锥形),甚至支持混合模式。
下面的视频就是名为 Plakato Color 的渐变字体设置色彩变化的效果录制(不动点击播放):
同时,相比 OpenType-SVG 格式要更简单更高效,因为是按照图层绘制的。
这么说吧,COLR/CPAL(v0) 和 OpenType-SVG 相比就是个弟弟,但是 COLR/CPAL(v1) 和 OpenType-SVG 相比就要强一个头。
OpenType-SVG 多半要逐渐在 Web 中落寞了。
二、font-palette 与字体颜色
好,关于彩色字体的基础知识介绍完了,下面可以讲讲本文的重点,也就是彩色字体的这个"彩色"的颜色控制了。
在过去,无论是普通字体还是彩色字体,如果想要表现出不一样的颜色或者纹理,往往需要使用 mask 遮罩,或者 background-clip:text 方法 进行模拟,或者使用 filter
滤镜或者 mix-blend-mode
混合模式(这两个属性学习见"FDCon2019大会分享之滤镜与混合模式实录"一文)进行变色。
但是上面这些方法都属于曲线救国,往往会丢失很多细节,效果并不如人意。
而 font-palette
属性专门用来改变彩色字体中的字形颜色的,配合 @font-palette-values
规则,可以让 CSS 对字符色彩的控制达到一个全新的高度。
浏览器已经支持了,学起来
最近几个版本的 Chrome 和 Safari 浏览器均已经支持彩色字体的显示了。
以现在浏览器更新换代的速度,不出一年,其实就可以在生产环境使用对应的技术了。
况且,此特性属于渐进增强的特性,就算浏览器不支持,也不影响初始的能力,因此,学起来,不要犹豫。
三、如何设置字体的调色?
彩色字体中有个调色板的概念,是字体在制作的时候定义了一系列的颜色组合。
font-palette
属性的作用就是调用其中指定的调色板。
因此,使用过程大致可以分为以下这三块:
- 自定义字体;
- 自定义字体中的调色板;
- 调用调色板。
1. 自定义字体
自定义字体使用 @font-face 规则,这里,我们使用一个名为 Rocher Color 的多彩字体进行示意,假设此字体文件名是 RocherColorGX.woff2。
则我们可以定义一个名为 'Rocher'
的自定义字体,这个字体使用的就是多色字体文件。
@font-face {
font-family: 'Rocher';
src: url(./RocherColorGX.woff2);
}
2. 自定义调色板
- 至于字体中的调色板定义,这个需要借助
@font-palette-values
规则,大家可以看下下面的 CSS 代码:
@font-palette-values --Zhangxinxu {
font-family: Rocher;
base-palette: 9;
}
表示定义了一个名为 --Zhangxinxu 的调色板,这个调色板使用的是第9号基础色板。
所谓的"基础色板",指的是字体制作时候内置的一系列调色板,使用 CSS base-palette
属性进行调用。
现在问题来了,我如何知道字体中有哪些色板呢?base-palette
属性后面的序号又是什么意思呢?
3. 调色板的获取和规则
有个名叫 Wakamai Fondue 的在线网站工具可以帮助识别字体中的颜色色板。
点击页面中间的圈圈就可以上传字体进行识别了:
此工具很强,不仅可以识别色板,字体特征(连字、字距、上下错落等),可变特性(内轮廓、外阴影、轮廓等)等都可以识别,大家可以收藏备忘下。
例如,这里可以识别 RocherColorGX.woff2 字体共有 11 个 4 色调色板,其中,第一个色板是默认的配色(浏览器不支持 font-palette 属性显示的颜色),序号是 0,然后往下依次是 1-9.
也就是 base-palette:0
表示使用的是默认色板,base-palette:1
使用的是第2个色板,依次类推。
4. 调用调色板
有了自定义的调色板,我们就可以使用 font-palette
属性调用了,例如:
.text {
font-palette: --Zhangxinxu;
}
此时 .text
选择器对应的元素中的字符就会调用调色板序号为 9 的色值显示,是有点灰灰的颜色效果,如下截图所示:
5. 完整代码与效果
将上面的代码整合一下,就有了完整的多彩字体颜色设置的实现了。
假设有如下的 HTML 元素:
<h4 class="grays">Color fonts</h4>
<h4 class="purples">Color fonts</h4>
<h4 class="mint">Color fonts</h4>
则下面的 CSS 可以让这三段文字分别显示不同的色板色值:
/* 自定义字体 */
@font-face {
font-family: 'Rocher';
src: url(./RocherColorGX.woff2);
}
h4 {
font-family: 'Rocher';
font-size: 50px;
}
/* 自定义调色板 */
@font-palette-values --Grays {
font-family: Rocher;
base-palette: 9;
}
@font-palette-values --Purples {
font-family: Rocher;
base-palette: 6;
}
@font-palette-values --Mint {
font-family: Rocher;
base-palette: 7;
}
/* 调用调色板 */
.grays {
font-palette: --Grays;
}
.purples {
font-palette: --Purples;
}
.mint {
font-palette: --Mint;
}
最终的渲染效果如下图所示(如果浏览器支持 font-palette 属性):
眼见为实,您可以狠狠地点击这里:@font-palette-values使用演示demo
如果您的浏览器版本还不足,则显示的效果会是默认的色板颜色,也就是棕黄色色板的效果,如下图所示:
四、override-colors 重置调色板颜色
除了使用默认的调色板色值,我们还可以使用 CSS override-colors
属性重置调色板中的颜色。
override-colors
属性同样只在 @font-palette-values
规则中使用才有效。
语法如下:
override-colors:
0 <color>,
1 <color>,
2 <color>,
...;
至于颜色的数量的多少是有字体决定的,例如 Rocher Color 这个字体的每个色板是 4 个颜色,则这里的 override-colors
就可以重置 4 个颜色值。
但是,具体哪个序号对于那块的色值是无法判断的,需要自己代码调试才知道。
我们来看一个使用案例,单独使用 override-colors
属性,则表示在默认的调色板上重置某些颜色值。
@font-palette-values --Default {
font-family: Rocher;
override-colors:
0 #2a80eb,
1 #eb4646,
2 #f59b00,
3 #1cad70;
}
.default {
font-palette: --Default;
}
意思是自定义一个名为 --Default 的调色板,里面的颜色将默认调色板的 4 个颜色全部覆盖了个遍。
此时设置了类名 default
的元素的英文字符渲染效果如下图所示:
如果我们只希望重置某个调色板中的具体的一两个色值,而不是全部,则此时可以和 base-palette
属性一起使用。
@font-palette-values --Palette6 {
font-family: Rocher;
base-palette: 6;
override-colors: 2 #f59b00;
}
此时调色板 --Palette6 中只有一个颜色覆盖成了橙色,截图效果见下面:
上述效果有对应的演示页面,您可以狠狠地点击这里:override-colors覆盖文字调色板颜色demo
其他有趣的展示
这里还有个演示页面,利用 override-colors
属性自定义 emoji 表情各个部位的颜色,原始地址是这里,如果无法访问了,也可以点击这里体验效果。
当改变了几个颜色值后,此时相关的 CSS 代码如下截图所示:
四、其他说明、结语等
对于中文环境,受制于字体文件过大,以及缺少对应的字体,因此,多色字体技术的实际应用不是中文的处理,更多的是英文数字,或者是某些彩色的矢量图标。
虽然目前也有彩色 icon 图标,但一般都是 SVG 绘制的,颜色的控制并不方便。
如果将其转换成彩色字体,再配合 font-palette
属性进行控制,那就方便多了。
不知道有没有自动转换的工具,理论上应该是可以支持的,不过我没找到,如果已经有了,欢迎大家进行反馈,我更新到文章中。
越来越期待以后的 Web 产品样式与形态了。
参考文章
行为不易,如果你觉得内容还不错,欢迎分享!
(本篇完)