Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sergiandreplace/flutter_rough
A Flutter implementation of the rough.js library
https://github.com/sergiandreplace/flutter_rough
art dart drawing flutter flutter-lib rough
Last synced: 4 months ago
JSON representation
A Flutter implementation of the rough.js library
- Host: GitHub
- URL: https://github.com/sergiandreplace/flutter_rough
- Owner: sergiandreplace
- License: mit
- Created: 2020-05-01T17:05:44.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2021-12-31T13:12:40.000Z (about 3 years ago)
- Last Synced: 2023-08-20T23:01:05.478Z (over 1 year ago)
- Topics: art, dart, drawing, flutter, flutter-lib, rough
- Language: Dart
- Size: 876 KB
- Stars: 82
- Watchers: 4
- Forks: 9
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/e6270/e62708daf2c768d5cbefe4cd98e5c91d849b3d1a" alt="Pub"](https://pub.dev/packages/rough)
[data:image/s3,"s3://crabby-images/45e3e/45e3e9de7b6e12a42c0d022245d1a16520b776d9" alt="GitHub Release Date"](https://pub.dev/packages/rough)
[data:image/s3,"s3://crabby-images/630f9/630f944825d645eb09394fa12f3e5034d78f7810" alt="GitHub"](https://github.com/sergiandreplace/flutter_rough/blob/master/LICENSE)# Rough
Rough is a library that allows you draw in a sketchy, hand-drawn-like style. It's a direct port of [Rough.js](https://roughjs.com/).
## Installation
In the `dependencies:` section of your `pubspec.yaml`, add the following line:
```yaml
dependencies:
rough:
```
## Basic usageRight now only drawing via canvas is supported. This is a basic documentation in case you want to play around with Rough. I can't ensure non-breaking changes of the library interface.
To draw a figure you have to:
1. Create a `DrawConfig` object to determine how your drawing will look.
2. Create a `Filler` to be used when drawing objects (you have to provide a configuration for the filling and a `DrawConfig` for the filling path).
3. Create a `Generator` object using the created `DrawConfig` and `Filler`. This will define a drawing/filling style.
4. Invoke the drawing method from the `Generator` to create a `Drawable`.
5. Paint the `Drawable` in the canvas using the `drawRough` method extension for `Canvas`.Here an example on how to draw a circle:
```dart
//Create a `DrawConfig` object.
DrawConfig myDrawConfig = DrawConfig.build(
roughness: 3,
curveStepCount: 14,
maxRandomnessOffset: 3,
);//Create a `Filler` with a configuration (we reuse the drawConfig in this case).
FillerConfig myFillerConfig = FillerConfig(
hachureGap: 8,
hachureAngle: -20,
drawConfig: myDrawConfig,
);
Filler myFiller = ZigZagFiller(myFillerConfig);//Create a `Generator` with the created `DrawConfig` and `Filler`
Generator generator = Generator(
myDrawConfig,
myFiller,
);//4. Build a circle `Drawable`.
Drawable figure = generator.circle(200, 200, 320);//5. Paint the `Drawable` in the canvas.
Canvas.drawRough(figure, pathPaint, fillPaint);
```And this is the result:
data:image/s3,"s3://crabby-images/81542/8154219c555a1b1673dfa74a6bb6b00bf435f532" alt="Result"
Both `DrawConfig` and `FillerConfig` will use default values for anything not specified.
## Samples
Some screenshots of the example app:
data:image/s3,"s3://crabby-images/a41fb/a41fb6477638fd2b2f9eceb619533e0bac0e5f46" alt="Example 1"
data:image/s3,"s3://crabby-images/c4603/c460363898822d26d09566f08a3e76b88fda1d7d" alt="Example 2"
data:image/s3,"s3://crabby-images/c81bf/c81bf4c0822dea40debcde20cf5e5ef9b136a5e0" alt="Example 3"
data:image/s3,"s3://crabby-images/14ca3/14ca38eaa2ae3d5250dc7fa7c50bda90b1fd7fd3" alt="Example 4"