前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用html5 canvas绘制自定义多边形动态能力分布图

使用html5 canvas绘制自定义多边形动态能力分布图

作者头像
用户5997198
发布2019-08-29 16:24:21
2.2K0
发布2019-08-29 16:24:21
举报
文章被收录于专栏:蚂蚁开源社区

有一个网友给了一张图,图片如下,

于是自己尝试了一下,用canvas看能否动态绘制能力分布图,以下是我的思路,有不足之处还望老司机们多多指教;

可以自定义参数如下:

废话不多说,先上效果图:

1、首先是绘制多边形,现在画布中心绘制圆形,然后在园中动态获取多边形的顶点,然后使用lineTo()方法绘制正多边形;效果图如下:

2、为了有层次感,需要再绘制两个小的正多边形,而且这几个多边形是需要有透明度的,如下图:

3、依次绘制对角线及最外层图标,如下图

5、然后就是绘制橙色能力部分以及所有能力之和的均值;如下图

6,最后就是使用setTimeOut或者requestAnimationFrame实现动画效果;

存在问题:

1、当绘制图形为偶数边多边形时,小图片下的介绍文字会显示不完全,如下图:

主要原因是偶数边多边形能的图标有分布在canvas的正下方区域,解决办法是适当调整图标所在圆形的半径(iconsRadius)和中心三个多边形的半径(polygons > radius);

2、绘制图在移动端会显示失真,图标显示会稍微不清楚;如下图:暂时没有找到解决办法,看社区网友能否有好的解决方法。请在帖子下方留言。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 蚂蚁大喇叭 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档