transform: scale(x,y)缩放后致使echarts图表模糊

1、将canvas转换成svg

  在初始化时就指定渲染器为svg: 

echarts.init(dom , null , { renderer : 'svg' });

  第一个参数是:echarts的容器;

  第二个参数是:颜色主题,没有可以设置为 null ;

  第三个参数是:说使用svg渲染器。

 注释:为什么使用 svg 渲染器就可以解决图表模糊的问题呢?

  1、canvas和svg的区别

  • canvas通过JS来绘制,只要它的位置发生改变,就得重新绘制svg使用XML的2d语言。
  • canvas它是基于像素点,依赖屏幕的分辨率,可能会失真svg不依赖屏幕分辨率,不会失真。
  • canvas适合图像密集的场景如:游戏svg不适合游戏。
  • canvas支持颜色比svg多。
  • svg 内存占用更低,渲染性更更高一些。

  

  2、需要注意的是

  • 目前的 svg中 富文本、材质功能尚未实现;所以对于效果复杂的echarts图来说不太理想; 但是柱状图,饼状图,折线图是没有任何问题的。可以使用svg渲染器。
  • 一般来说,Canvas 更适合绘制图形元素数量非常大(这一般是由数据量大导致)的图表. (如热力图、地理坐标系或平行坐标系上的大规模线图或散点图等)也利于实现某些视觉 特效。
  • svg具有重要的优势:它的内存占用更低(这对移动端尤其重要)、渲染性能略高、浏览器缩放功能时不会模糊。 SVG 渲染器在折、柱、饼图上相对canvas更好一些。

 

posted @ 2022-10-14 10:09  陈醋当墨写尽人生酸楚  阅读(466)  评论(0编辑  收藏  举报