Flutter 112: 图解自定义 ACEPieWidget 饼状图 (一)
2023-02-26 10:20:36 时间
小菜准备展示一个简单的饼状图,因需要比较简单单一,所以小菜准备自己绘制一个;今天小菜只尝试绘制过程,暂不涉及手势操作;
ACEPieWidget
小菜对于绘制分为三个步骤:
(福利推荐:阿里云、腾讯云、华为云服务器最新限时优惠活动,云服务器1核2G仅88元/年、2核4G仅698元/3年,点击这里立即抢购>>>)
- 类别选项球;
- 切割绘制饼状图;
- 饼状图中绘制文字;
1. 类别选项球
对于两侧不同颜色类别选项卡,仅需要简单设置一下 Container 的 decoration 装饰器即可,只是方便用户查看饼状图分类而已;
return Container( height: 45, width: 45, margin: EdgeInsets.symmetric(vertical: 2.5, horizontal: 10), decoration: BoxDecoration(color: _color, borderRadius: BorderRadius.circular((25.0))), child: Center(child: Text(_text, style: TextStyle(fontSize: 12, color: Colors.white))));
2. 饼状图绘制
对于 Canvas 的基本绘制,小菜在之前的博客中有过简单介绍;此次小菜也是使用最基本的 drawArc 绘制扇形拼接为一个完整圆形方式;
- 获取 ListData 总的数据值;
- 遍历 ListData 根据各个子类别数据比例和旋转角度进行不同颜色的扇形图绘制;
- 最终拼接为完整饼状图;
注意:在绘制扇形图时需要注意扇形图的起始角度和终止角度,需要累加上一次绘制的扇形图角度;
// 1. 设置画笔 Paint _paint = Paint()..color = Colors.grey ..strokeWidth = 4.0..style = PaintingStyle.fill; // 2. 获取 ListData 总的数据值 _sumData() { if (_listData != null) { for (int i = 0; i < _listData.length; i++) { _sum += _listData[i].values.first; } } } // 3. 根据各个子类别数据比例和旋转角度进行不同颜色的扇形图绘制 if (_listData != null) { for (int i = 0; i < _listData.length; i++) { startAngle += sweepAngle; sweepAngle = _listData[i].values.first * 2 * PI / _sum; canvas.drawArc(_circle, startAngle, sweepAngle, true, _paint..color = _subPaint(_listData[i].keys.first)); } } }
3. 文字绘制
饼状图绘制好之后就是在各自的扇形面积上绘制文字;其中小菜规定,只有扇形图角度大于等于 30 度的时候才会进行文字绘制,如果扇形图角度太小绘制显示效果不佳;
- 文字的初始绘制点默认是以屏幕左上角为坐标原点,此时在扇形面内进行绘制时首先需要通过 translate() 平移坐标系至饼状图圆心;
- 绘制文字的角度要与扇形的角平分线平行,此时通过 rotate() 对坐标系进行适当角度的旋转;
- 小菜无法得知文字占据坐标长度,但是可以通过 Paragraph 获取文字绘制时所占据高度,因此在通过 drawParagraph 绘制文字时适当设置文字起始坐标,y 轴坐标向上平移文字高度的一半;
- 再文字绘制结束之后,将坐标系 rotate() 旋转回正常水平竖直方向,并将起始坐标 translate() 平移恢复至屏幕左上角;待下次文字绘制;
// 1. 绘制文笔属性(颜色,尺寸等)和最大段落宽度 ParagraphBuilder _pb = ParagraphBuilder(ParagraphStyle( textAlign: TextAlign.left, fontWeight: FontWeight.w600, fontStyle: FontStyle.normal, fontSize: 14)) ..pushStyle(ui.TextStyle(color: Colors.white)); ParagraphConstraints _paragraph = ParagraphConstraints(width: size.width * 0.5); if (sweepAngle >= PI / 6) { // 2. 平移坐标系 canvas.translate(size.width * 0.5, size.height * 0.5); // 3. 设置旋转角度 canvas.rotate(startAngle + sweepAngle * 0.5); // 4. 文字绘制 Paragraph paragraph = (_pb..addText(_subName)).build()..layout(_paragraph); canvas.drawParagraph(paragraph, Offset(50.0, 0.0 - paragraph.height * 0.5)); // 5. 恢复旋转角度 canvas.rotate(-startAngle - sweepAngle * 0.5); // 6. 恢复起始坐标 canvas.translate(-size.width * 0.5, -size.height * 0.5); }
ACEPieWidget 案例源码
小菜仅简短的介绍了一下基本饼状图的样式绘制,其功能还不够完善,后续会加入适当的手势操作;如有错误,请多多指导!
来源: 阿策小和尚
你还在原价购买阿里云、腾讯云、华为云、天翼云产品?那就亏大啦!现在申请成为四大品牌云厂商VIP用户,可以3折优惠价购买云服务器等云产品,并且可享四大云服务商产品终身VIP优惠价,还等什么?赶紧点击下面对应链接免费申请VIP客户吧:
相关文章
- Jgit的使用笔记
- 利用Github Action实现Tornadofx/JavaFx打包
- 叹息!GitHub Trending 即将成为历史!
- 微软软了?开源社区讨论炸锅,GitHub CEO 亲自来答
- GitHub Trending 列表频现重复项,前后端都没去重?
- Photoshop Elements 2021版本软件安装教程(mac+windows全版本都有)
- (ps全版本)Photoshop 2020的安装与破解教程(mac+windows全版本都有)
- (ps全版本)Photoshop cc2018的安装与破解教程(mac+windows全版本,包括2023
- 环境搭建:Oracle GoldenGate 大数据迁移到 Redshift/Flat file/Flume/Kafka测试流程
- 每个开发人员都要掌握的:最小 Linux 基础课
- 来撸羊毛了!Windows 环境下 Hexo 博客搭建,并部署到 GitHub Pages
- 超实用!手把手入门 MongoDB:这些坑点请一定远离
- 【GitHub日报】22-10-09 zustand、neovim、webtorrent、express 等4款App今日上新
- 【GitHub日报】22-10-10 brew、minio、vite、seaweedfs、dbeaver 等8款App今日上新
- 【GitHub日报】22-10-11 cobra、grafana、vue、ToolJet、redwood 等13款App今日上新
- Photoshop 2018 下载及安装教程(mac+windows全版本都有,包括最新的2023)
- Photoshop 2017 下载及安装教程(mac+windows全版本都有,包括最新的2023)
- Photoshop 2020 下载及安装教程(mac+windows全版本都有,包括最新的2023)
- Photoshop 2023 资源免费下载(mac+windows全版本都有,包括最新的2023)
- 最新版本Photoshop CC2018软件安装教程(mac+windows全版本都有,包括2023