CanvasKit & opentype.js 实现文字阴影

这次的主角其实不是 CanvasKit, 而是 opentype.js, 本次目标主要想利用它获取文本的 Path.

当然获取 Path 不止这一种, 还有个 gero3/facetype.js. 不过官方介绍它生成的路径主要为了 Threejs, 我自己也看不明它生成的字体路径在 Threejs 之外应该怎么用.

opentype.js

opentype.js is an OpenType and TrueType font parser and writer. It allows you to access the letterforms of text from the browser or node.js.

我们可以利用它对文字字形 Glyph 做更细致的操作, 修改字符的形态等. 当然这一切都是建立在 opentype.js 能获取到一个字体字符的 Path 的基础上, 并且支持多语言.

opentype.js 的 Font 对象下有这样的方法 Font.getPath(text, x, y, fontSize, options)

得到 path 后就可以塞入到 canvaskit.js 中操作了.

opentype.js 的 Path 同样提供了 getBoundingBox() 方法

canvaskit.js

我们的目标是给文字加上阴影, 也就是要做一个探照灯的效果.

在配合 CanvasKit 的过程中, 唯一要注意的是处理原始 Path 的 transform.

通过 svg-path-visualizer.netlify.app 可以看到文字顶部 Y 值是负数

上一篇介绍了 CanvasKit 中 Paint 用法, 本篇就说明一下 CanvasKit 中滤镜 Mask 来实现模糊.

和标准 Canvas API 不同的是, CanvasKit 在模糊和非模糊效果之间切换不需要 save restore 来保存状态. 因为 Mask 是作用在 Paint 上, 当不用 Mask 时取消滤镜即可.

很容易在 Skia 仓库中找到相关例子

>>> Github

相关推荐
pusheng20256 分钟前
燃料电池电化学传感器在硫化物固态电池安全监测中的技术优势解析
前端·人工智能·安全
それども7 分钟前
Excel文件解析 - SAX和DOM方式的区别
java·前端·excel
それども9 分钟前
Excel文件解析 - SAX startRow cell endRow 执行顺序
java·前端·excel
Byron070710 分钟前
基于 Vue 的微前端架构落地实战:从 0 到 1 搭建企业级多应用体系
前端·vue.js·架构
一位搞嵌入式的 genius11 分钟前
从 URL 到渲染:JavaScript 性能优化全链路指南
开发语言·前端·javascript·性能优化
芭拉拉小魔仙11 分钟前
Vue 3 组合式 API 详解:告别 Mixins,拥抱函数式编程
前端·javascript·vue.js
别叫我->学废了->lol在线等12 分钟前
taiwindcss的一些用法
前端·javascript
感谢地心引力18 分钟前
在Chrome浏览器中使用Gemini,附一键开启方法
前端·chrome·ai·gemini
晚霞的不甘20 分钟前
Flutter for OpenHarmony 豪华抽奖应用:从粒子背景到彩带动画的全栈实现
前端·学习·flutter·microsoft·前端框架
云和数据.ChenGuang24 分钟前
python 面向对象基础入门
开发语言·前端·python·django·flask