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

【fabric.js】toDataURL 性能问题、优化

必要解释:最好看完。。省流版的话,toDataURL 的 multiplier参数不要设置超过500;

情景:在做某些功能的时候涉及到图形的预览,预览的时候是导出为40*40 像素的图片,当碰到某些图形非常小的时候,例如该图形是0.01宽/0.01高,那么如果想要得到该图形40*40大小的图片则需要放大非常大的倍数 multiplier,从而导致 toDataURL 一个函数就需要执行1秒(根据放大倍数而定),且放大的倍数 multiplier 有一个临界值,当multiplier的值超过xxx时,multiplier每提高一段倍数,所需的时间更长。例如multiplier800是1秒,multiplier1200是2秒 (当时情况已经忘了,所以只是打个比方,感兴趣的自己测下就知道了)。。

吐槽:当时解决大量图形的性能瓶颈,解决完虚拟化列表后,自测时还是发现某些情况下(某些素材)加载时、操作时有性能问题,当时找了半天最后才发现是 toDataURL 导致的性能问题;


解决方案:

宽||高超过40的就是缩小了,不存在性能问题;
0.01*0.01的图形放大至40的时候,40/0.01就会得到4000的倍率,而且这么这么小的图形即使放大,也看不清,故而采取措施为将该图形不进行图片提取,反正拿到图片你也看不见这图形,不如不拿就完事了。。

本文其实就是讲解思路和问题点所在,代码案例写不写无所谓,没啥复杂的,但也分享下自己案例的相关片段;

          val.clone(async (newShape: fabric.Object) => {const options = {strokeWidth: 1,} as any;if (newShape.stroke) {options.stroke =newShape.processMode === ProcessMode.cut? newShape.originStrokeForCut: newShape.originStroke;}const w = newShape.width && 30 / (newShape.width * (newShape.scaleX as number));const h = newShape.height && 30 / (newShape.height * (newShape.scaleY as number));const multiplier = Math.min((w || h) as number, (h || w) as number);e.base64 = '';if (multiplier < 500) {multiplier < 1 && (options.strokeWidth = (1 / multiplier) * 1.5);newShape.set(options);e.base64 = newShape.toDataURL({multiplier,});}});

http://www.lryc.cn/news/288398.html

相关文章:

  • 基于Grafana+Prometheus搭建可视化监控系统实践
  • 选择排序(堆排序和topK问题)
  • webpack tree shaking 摇树原理
  • 开源模型应用落地-业务整合篇(三)
  • js打地鼠
  • 计算机网络体系架构认知--网络协议栈
  • Ubuntu 22.04 安装tomcat
  • 记录:Ubuntu 18.04 X86 上通过CMake 指定编译器工具链交叉编译。
  • requests,js逆向练习
  • Chrome 插件调试
  • 云轴科技ZStack成为交通运输业上云用云推进中心首批成员单位
  • 代码随想录算法训练营31期day4,力扣24+19+02.07+142
  • eNSP学习——利用单臂路由实现VLAN间路由
  • ISO27001认证:企业与个人发展的必备之选
  • SpringBoot使用druid
  • TongWeb8交流常见问答集
  • GBASE南大通用分享-mysql中的load data infile用法
  • Ubuntu18编译jdk8源码
  • 《开始使用PyQT》 第01章 PyQT入门 02 安装Python3和PyQT6
  • Java集合-Map接口(key-value)
  • 【操作系统】实验九 写一个设备驱动程序
  • 基于密码技术的身份认证——基于对称密码体制的身份认证
  • 算法36:单调栈结构、子数组最小乘积的最大值问题(力扣1586)----单调栈
  • django mysql in 有序返回
  • c++24.1.26嵌套if语句
  • 机器学习--基础概念(二)
  • Ubuntu20.04 安装 ROS noetic + MAVROS
  • 【数学笔记】一元n次不等式,分式不等式,绝对值不等式
  • 转载-android性能优化
  • 笔记 | Clickhouse命令行查询