Look at the overall effect first
data:image/s3,"s3://crabby-images/2ca4b/2ca4b515f3858e39dd49230f369fe06c03bfc254" alt=""
rely on
Dependency in "pubspec.yaml"
ele_progress:^version
The latest version number can be viewed in "pub": "ele_progress" address: https://pub.dev/packages/ele_progress
Import
import 'package:ele_progress/ele_progress.dart';
theme
The style of global setting "ele_progress" needs to use "EleTheme", and the code is as follows:
@override Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Demo', theme: ThemeData( primarySwatch: Colors.blue, ), home: EleTheme( data: EleThemeData(), child: ProgressDemo(), ), ); }
The library comes with a set of default styles.
attribute
- Progress: progress, value range: 0-100.
- "Colors": the color of the progress bar. This is an array type. Set one color to represent a solid color and multiple to be gradient colors.
- backgroundColor: the background color of the progress bar.
- "type": four progress bar styles are supported, namely "line", "circle", "dashboard" and "liquid".
- "strokeWidth": the width of the progress bar. The default is 6. It does not work when type=liquid.
- "showText": whether to display progress text. The default is true
- "textInside": whether the progress text is displayed in the progress bar. The default is false. It is only available when type=line and liquid.
- "true": indicates to follow the progress bar.
- "false": type=line and direction=horizontal. The text is displayed on the right side of the progress bar. In other cases, the text is displayed in the middle of the progress bar.
- format: customize the display progress text.
- "textStyle": progress text font style.
- "status": controls the color of the progress bar. It is used in conjunction with "theme". There are five states of "primary, success, info, warning and danger", corresponding to five colors: primaryColor, successColor, infoColor, warningColor and dangerColor. However, this attribute will be overwritten by the "colors" attribute.
- "Direction": the direction of the progress bar. It works when type=line and liquid.
- borderColor: border color. It works when type=liquid.
- "borderWidth": border width. It works when type=liquid.
- radius: border fillet. It works when type=liquid.
use
The simplest use
EProgress(progress: 50)
data:image/s3,"s3://crabby-images/25ef6/25ef6cfdde04ca7b5699949f5df8199bcbafb061" alt=""
"Progress" indicates progress, and the value range is 0-100.
The progress bar supports four shapes: line, circle, dashboard and liquid.
EProgress( progress: 50, type: ProgressType.liquid, )
data:image/s3,"s3://crabby-images/294a3/294a36b01d0875aa953bc8b6233a41e59887b022" alt=""
"Colors": indicates the color of the progress bar. This is an array type. Set one color to represent a solid color and multiple to be gradient colors.
EProgress( progress: _animation.value, strokeWidth: 20, colors: [ Colors.blue, Colors.red, Colors.green, ], )
data:image/s3,"s3://crabby-images/d3b85/d3b85ddb39a1ab29c39b3adb6d2fc0c16cc3ff9b" alt=""
backgroundColor: indicates the background color of the progress bar.
EProgress( progress: 50, strokeWidth: 20, backgroundColor: Colors.grey, )
data:image/s3,"s3://crabby-images/585b2/585b2bcdba4a68383112744ca042cb4735e5c4bc" alt=""
The width of the "strokeWidth" progress bar. The default is 6.
EProgress( progress: 50, strokeWidth: 20, )
"strokeWidth" does not work in the "type=liquid" style.
data:image/s3,"s3://crabby-images/b525c/b525c289efa583fd147bda10b40b2be49f8ff626" alt=""
Properties involving progress text are
- "showText": whether to display. The default is true
- "textInside": whether the progress text is displayed in the progress bar. The default is false. It is only available when type=line and liquid.
- "true": indicates to follow the progress bar.
- "false": type=line and direction=horizontal. The text is displayed on the right side of the progress bar. In other cases, the text is displayed in the middle of the progress bar.
- format: customize the display progress text.
- textStyle: font style.
EProgress( progress: _animation.value, strokeWidth: 20, textInside: true, )
data:image/s3,"s3://crabby-images/864d2/864d27c421ed6c1875d13b0135aa3b598342acce" alt=""
EProgress( progress: _animation.value, strokeWidth: 20, format: (progress) { return 'Custom: $progress%'; }, textStyle: TextStyle(color: Colors.red), )
data:image/s3,"s3://crabby-images/c8dd5/c8dd50a5364e255f5c0210d436e8a42c11daec41" alt=""
The "status" attribute is used in conjunction with "theme". There are five statuses of "primary, success, info, warning and danger" in the theme, corresponding to five colors
data:image/s3,"s3://crabby-images/cc6d3/cc6d33190adbf0654547e2d2aacaae755894f45e" alt=""
This color will be overwritten by "colors".
EProgress( progress: 50, strokeWidth: 20, status: EleThemeStatus.success, )
data:image/s3,"s3://crabby-images/aa65c/aa65c636cabf44d3a0cb49a9acb2141d84ed0a6e" alt=""
"Direction" indicates the direction of the progress bar. It works when type=line and liquid.
EProgress( progress: _animation.value, strokeWidth: 50, direction: Axis.vertical, )
data:image/s3,"s3://crabby-images/23641/23641be456abc5dfc937545dec3b4847cf7606e5" alt=""
borderColor, borderWidth and radius are used to set the border style. They work when type=liquid.
EProgress( progress: 50, type: ProgressType.liquid, borderColor: Colors.red, borderWidth: 5, radius: 30, )
data:image/s3,"s3://crabby-images/46f40/46f4008258c34e87f176f7cd53fed4dae355bcbe" alt=""
Conclusion
This is the first component imitating the "Element" style, and there will be many later. Please click to read the original text for other components.