Flutter 自绘组件 (CustomPaint与Canvas)绘制虚线、区域、直线
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text('自绘组件示例'),
),
body: Center(
child: CustomPaint(
size: Size(200, 200),
painter: MyPainter(),
),
),
),
);
}
}
class MyPainter extends CustomPainter {
@override
void paint(Canvas canvas, Size size) {
final paint = Paint()
..color = Colors.blue
..strokeWidth = 2
..style = PaintingStyle.stroke; // 设置画笔为描边模式
final path = Path();
path.moveTo(10, 30); // 开始点
path.relativeLineTo(100, 0); // 水平线
path.relativeLineTo(0, 100); // 垂直线
path.relativeLineTo(-100, 0); // 水平线
path.close(); // 关闭路径形成闭环,形成一个矩形区域
canvas.drawPath(path, paint); // 绘制路径
}
@override
bool shouldRepaint(CustomPainter oldDelegate) {
return false; // 是否需要重绘,false表示不重绘
}
}
这段代码创建了一个自定义的CustomPaint
组件,并通过MyPainter
类中的paint
方法来绘制一个蓝色的矩形区域。通过Path
对象来定义形状,并使用Canvas
对象的drawPath
方法进行绘制。这个示例展示了如何使用Path
来创建一个简单的图形,并且如何使用CustomPainter
来进行自定义绘制。
评论已关闭