Canvas 的性能卓越,用它解决一个棘手问题

很早以前就写过一篇文章说明 canvas 计算文字宽高的文章,但是当时理解并没有那么深入,直到最近解决一个棘手的问题:思维导图文字显示不全问题。

简单复现场景:

  1. Windows 下的浏览器(edge、chrome 均可)编辑思维导图节点文字

  2. Mac 上查看该思维导图节点就会出现文字显示不全

技术上的说明:

  1. 当前文字宽高计算是在文字编辑过程中计算的,使用 canvas 计算文本宽高

  2. 文字宽高存在思维导图节点数据上,渲染的时候直接使用

  3. 「文字编辑过程中计算」是导致这个问题的根本原因,不同操作系统的文字排版方式不同 + 不同操作系统上的浏览器默认字体不同,导致即使同时 Chrome 浏览器并且都是用 canvas 计算方案得到的结果也是无法兼容的,windows 下计算的文字宽度明显小于 mac 下的文字宽度

  4. 最终导致 Windows 浏览器上编写的思维导图在 Mac 上无法正常展示,Mac 浏览器上编写的思维导图在 Windows 上正常

解决方案:

  1. 渲染时基于 canvas 重新计算文字宽高,相当于渲染是基于当前电脑的浏览器环境重新计算,这样不会有任何兼容性问题

  2. 引入简单的缓存,已经计算过的文本直接读缓存

  3. 最初担心性能问题,测试发现不同样本的数据每计算 1000 次宽高平均花费的时间在 5ms ,这个开销完全可接受,甚至算高效

总结:

其实文字显示不全的问题困扰我们好久,大概拖了好几个月,中间用过非常蹩脚的办法(显示不全时出现滚动条,这个体验很差),一直因为担心性能问题、没有明确的复现路径等导致没有解决,下定决定基于 canvas 动态计算也是因为仔细研究了「语雀」的方案,发现它在不同的系统上渲染的文字宽高确实不同,然后又测试下 canvas 的性能表现,发现这个方案基本上很完美。

> 大家对于开源白板、开源思维导图感兴趣,可以关注、了解 Drawnix: GitHub - plait-board/drawnix: 开源白板工具(SaaS),一体化白板,包含思维导图、流程图、自由画等。All in one open-source whiteboard tool with mind, flowchart, freehand and etc.

> 对思维导图、白板、画笔工具有使用需求可直接访问 drawnix.com

相关推荐
qq_177767379 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头88219 小时前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
天人合一peng11 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling12 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐12 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区12 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO12 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu1213813 小时前
Vuex介绍
前端·javascript·vue.js
We་ct13 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_9494800613 小时前
【无标题】
开发语言·前端·javascript