Flutter 自绘制 Widget

点击“奇舞移动技术”关注我们!

内容简介

Flutter Team 已经提供了很多的 widget,风格也不同,比如 Android 的 Material Design 、iOS 的 Cupertino 等等。在大多数情况下,是可以满足基本需求的。但是遇到高度定制化的需求,就难以满足,好在自定义的方式可以满足我们。

Widget 呈现方式

1、组合方式

我们一般实现的布局方式,基本都是排列组合的方式完成的布局组件树,来呈现布局。

2、自己绘制方式

这种方式的使用,基本上是复杂度较高的组件,比如数据可视化需求的南丁格尔玫瑰图,饼状图,多边形等等。

怎样自绘制?

Flutter “毫无创新”地给出类似于很多2D UI系统的画布+画笔的方式完成自定义绘制。具体涉及到的类有:Canvas、Paint、CustomPainter。自定义 CustomPainter 的类,直接看一下代码,如下:

List<Offset> _points = <Offset>[];

class MyCustomPainter extends CustomPainter {
  MyCustomPainter(this.points);

  final List<Offset> points;

  Paint _paint = new Paint()
    ..color = Colors.black
    ..strokeCap = StrokeCap.round
    ..isAntiAlias = true
    ..strokeWidth = 7.0
    ..strokeJoin = StrokeJoin.bevel;

  @override
  void paint(Canvas canvas, Size size) {
    for (int i = 0; i < points.length - 1; i++) {
      if (points[i] != null && points[i + 1] != null) {
        canvas.drawLine(points[i], points[i + 1], _paint);
      }
    }
  }

  @override
  bool shouldRepaint(CustomPainter oldDelegate) => true;
}

重写了两个方法:

1、paint(Canvas canvas, Size size) 绘制的具体操作在这里执行;

2、shouldRepaint 表示当前的 widget 绘制完成后就不需要重新绘制了,自定义组件返回 ture。

利器介绍

画笔 Paint

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值