老孟导读:CustomPaint能够称之为动画鼻祖,它能够实现任何酷炫的动画和效果。CustomPaint自己没有动画属性,仅仅是绘制属性,通常状况下,CustomPaint会和动画控制配合使用,达到理想的效果。git
CustomPaint的用法很是简单,以下:canvas
CustomPaint(
painter: MyCustomPainter(),
)复制代码
MyCustomPainter定义以下:微信
class MyCustomPainter extends CustomPainter {
@override
void paint(Canvas canvas, Size size) {}
@override
bool shouldRepaint(MyCustomPainter oldDelegate) {
return this != oldDelegate;
}
}复制代码
上面的MyCustomPainter为了看起来清晰,什么也没有作,一般状况下,在paint
方法内绘制自定义的效果。shouldRepaint
方法一般在当前实例和旧实例属性不一致时返回true。ide
paint
经过canvas
绘制,size
为当前控件的大小,下面看看canvas
的方法。函数
Paint _paint = Paint()
..color = Colors.red
..strokeWidth = 3;
@override
void paint(Canvas canvas, Size size) {
var points = [
Offset(0, 0),
Offset(size.width / 2, size.height / 2),
Offset(size.width, size.height),
];
canvas.drawPoints(PointMode.points, points, _paint);
}复制代码
PointMode
有3种模式:动画
canvas.drawLine(Offset(0, 0),Offset(size.width, size.height), _paint);复制代码
Paint _paint = Paint()
..color = Colors.red
..style = PaintingStyle.stroke
..strokeWidth = 3;
@override
void paint(Canvas canvas, Size size) {
print('size:$size');
var _path = Path()
..moveTo(0, 0)
..lineTo(size.width, 0)
..lineTo(size.width, size.height)
..close();
canvas.drawPath(_path, _paint);
}复制代码
这里注意Paint.style
,还能够设置为PaintingStyle.fill
,效果以下:this
此时Path的路径不要在一条直线上,不然会看不到效果。spa
绘制圆形3d
canvas.drawCircle(Offset(size.width/2, size.height/2), 20, _paint);复制代码
绘制椭圆code
canvas.drawOval(Rect.fromLTRB(0, 0, size.width, size.height/2), _paint);复制代码
若是给定的Rect为正方形,那么椭圆将会变为圆形。
绘制弧
canvas.drawArc(
Rect.fromLTRB(0, 0, size.width, size.height), 0, pi/2, true, _paint);复制代码
绘制圆角矩形
canvas.drawRRect(
RRect.fromLTRBR(0, 0, size.width, size.height, Radius.circular(10)), _paint)复制代码
canvas
还有不少绘制函数,好比贝塞尔曲线、三次贝塞尔曲线、画布的反转等操做,这里不在一一介绍。
这些函数和Android的Canvas基本同样,若是你有Android基础,直接套用便可。
最后奉上一个绘制玫瑰的动画效果:
这个效果是否是很酷炫,咱们看下绘制花骨朵代码:
///
/// 绘制花骨朵
///
_drawFlower(Canvas canvas, Size size) {
//将花变为红色
if (flowerPaths.length >= RoseData.flowerPoints.length) {
var path = Path();
for (int i = 0; i < flowerPaths.length; i++) {
if (i == 0) {
path.moveTo(flowerPaths[i].dx, flowerPaths[i].dy);
} else {
path.lineTo(flowerPaths[i].dx, flowerPaths[i].dy);
}
}
_paint.style = PaintingStyle.fill;
_paint.color = _flowerColor;
canvas.drawPath(path, _paint);
}
//绘制线
_paint.style = PaintingStyle.stroke;
_paint.color = _strokeColor;
//去掉最后2个点,最后2个点为了绘制红色
var points = flowerPaths.sublist(0, max(0, flowerPaths.length - 2));
canvas.drawPoints(PointMode.polygon, points, _paint);
}复制代码
花骨朵的绘制只经过canvas.drawPath
就实现了,其实整个玫瑰花的绘制都是经过canvas.drawPath
加上动画控制实现的。
CustomPaint能够实现任何你想要的动画的效果,好比绘画版就能够经过此控件实现。
获取完整代码方式扫码下方二维码回复:rose
老孟Flutter博客地址(近200个控件用法):laomengit.com
欢迎加入Flutter交流群(微信:laomengit)、关注公众号【老孟Flutter】:
![]() |
![]() |