Elliptical progress bar
New Features
- Now the progressbar is Stateful
- Added new progressbar AnimatedEllipticalProgressBar with animation
Features
- Responsive
- Customizable
- Easy styling
Installing
flutter pub add elliptical_progress_bar
Important
The aspect ratio of the graph is 3:1, adjust required thickness accordingly.
Usage
ANIMATED ELLIPTICAL PROGRESS BAR
class _MyHomePageState extends State<MyHomePage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text('Elliptical progress bar'),
        ),
        body: SingleChildScrollView(
          child: Padding(
            padding: const EdgeInsets.all(10),
            child: 
                AnimatedEllipticalProgressBar(
                fillColor: Colors.grey,
                bgColor: Colors.black.withOpacity(0.5),
                thickness: 20,
                progress: 80,
                textColor: Colors.red,
                progressTextStyle: const TextStyle(fontSize: 30),
              ),
            ),
          ),
        );
  }
}
ELLIPTICAL PROGRESS BAR (without animation)
class _MyHomePageState extends State<MyHomePage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text('Elliptical progress bar'),
        ),
        body: SingleChildScrollView(
          child: Padding(
            padding: const EdgeInsets.all(10),
            child: 
                EllipticalProgressBar(
                  fillColor: Colors.red,
                  bgColor: Colors.red.withOpacity(0.5),
                  thickness: 30,
                  progress: 70,
                  textColor: Colors.blue,
                  showCenterProgress: false,
                ),
            ),
          ),
        );
  }
}
Props
| Name | Value | Description | 
|---|---|---|
| fillColor | Color | Color to show the progress with. | 
| bgColor | Color | Color to show the loop with. | 
| progress | double | Progress value (0 - 100). | 
| textColor | Color, optional | Color to show the progress text in center with. | 
| showCenterProgress | bool, default - true, optional | enable to show the center progress value, set to false to hide | 
| thickness | double, default - 10, optional | set the thickness of the loop | 
| progressTextStyle | TextStyle, optional | To customise the center progress text style |