当前位置: 首页 > news >正文

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
 
http://www.wxhsa.cn/company.asp?id=841

相关文章:

  • fastapi
  • 非线性技术之所以重要,是因为非线性问题不像线性问题那样可以统一求解,其复杂性往往要求我们结合理论、几何、数值、统计、甚至物理直觉进行处理。
  • Oracle主键primary key
  • Kubernetes标签(Label)
  • Gitee DevOps平台深度评测:本土化优势如何赋能企业研发效能提升
  • 【SPIE出版】2025计算机视觉和影像计算国际学术会议(CVIC 2025)
  • 密码学工具包中的Hash函数
  • 跟着院士导师做会议口头汇报PPT!
  • 【分享】内外网文件传输方式:从传统痛点到专业解决方案!
  • c# TargetFramework 应该写 net48 还是 net4.8
  • Docker 安装 Elasticsearch 报错
  • 大疆红外TSDK红外照片转RGB888图片JAVA实现方法
  • MCU联网
  • 算法-A*-01 - jack
  • 代码是上午写的,公司是下午解散的!
  • [antlr] 如何在Linux(Ubuntu)环境中安装配置antlr4.9.2
  • 国内开发者如何选择代码管理平台?Gitee、GitHub与Bitbucket深度对比
  • Spring-Android-即时入门-全-
  • 4. 链表
  • Maven-和-Eclipse-全-
  • Prompt、RAG、微调
  • 飞书对程序员下手了,0 代码生成各类系统!!
  • 测试用例设计检查项
  • Android Kotlin请求权限及权限回调处理
  • 版本发布| IvorySQL 4.6 发布
  • Avalonia Calendar 日历控件遇到 Flyout 或者切换页面时出现的鼠标按下失效的解决方法
  • cache和主存的映射方式
  • Vue 2 + Element UI 技术栈的管理端项目和Git使用教程
  • 你好
  • 2025年图像、信号处理与机器学习国际学术会议(ISPML 2025)