blob: 8d62f94abb5783947478c3af728d591246b876a1 [file] [log] [blame] [view]
# path_drawing
[![pub package](https://img.shields.io/pub/v/path_drawing.svg)](https://pub.dev/packages/path_drawing)
A Flutter library to assist with creating and manipulating paths.
Currently supports parsing a `Path` from an SVG path data string
(including normalizing the path commands to be amenable to Flutter's exposed
Path methods).
Dash paths has an initial implementation that relies on flutter 0.3.6 at a minimum.
Planned for future release(s):
- Trim paths
## Example
Parse some path from svg string:
```dart
import 'package:path_drawing/path_drawing.dart';
final trianglePath = parseSvgPathData('M150 0 L75 200 L225 200 Z');
```
Create [CustomPainter](https://api.flutter.dev/flutter/rendering/CustomPainter-class.html):
```dart
class FilledPathPainter extends CustomPainter {
const FilledPathPainter({
@required this.path,
@required this.color,
});
final Path path;
final Color color;
@override
bool shouldRepaint(FilledPathPainter oldDelegate) =>
oldDelegate.path != path || oldDelegate.color != color;
@override
void paint(Canvas canvas, Size size) {
canvas.drawPath(
path,
Paint()
..color = color
..style = PaintingStyle.fill,
);
}
@override
bool hitTest(Offset position) => path.contains(position);
}
```
Use it inside [CustomPaint](https://api.flutter.dev/flutter/widgets/CustomPaint-class.html):
```dart
class MyWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return GestureDetector(
onTap: () => print('tap'),
child: CustomPaint(
painter: FilledPathPainter(
path: trianglePath,
color: Colors.blue,
),
),
);
}
}
```
More examples can be found in [example folder](example/lib/main.dart)