Flutter圆形进度条插件flutter_rounded_progress_bar的使用
Flutter圆形进度条插件flutter_rounded_progress_bar的使用
概述
flutter_rounded_progress_bar
是一个自定义的圆形进度条插件,可以用于在 Flutter 应用中显示圆形进度。它支持多种样式和主题,并且可以自定义进度条的各个部分。
特点
- 支持多种位置的子组件(
childCenter
,childLeft
,childRight
) - 支持多种主题
- 可以自定义样式
- 支持动画效果
安装
在 pubspec.yaml
文件中添加依赖:
dependencies:
flutter_rounded_progress_bar: 0.2.0
然后运行 flutter pub get
来安装依赖。
使用方法
基本用法
创建一个简单的圆形进度条:
RoundedProgressBar(
childLeft: Text("$percent%",
style: TextStyle(color: Colors.white)),
percent: percent,
theme: RoundedProgressBarTheme.green)
子组件位置
RoundedProgressBar
支持三种位置的子组件:childCenter
, childLeft
, childRight
。
RoundedProgressBar(
childCenter: Text("$percent%"),
percent: percent,
)
自定义样式
使用 RoundedProgressBarStyle
类来自定义进度条的样式。
RoundedProgressBar(
style: RoundedProgressBarStyle(
widthShadow: 30, colorBorder: Colors.blue[200]),
percent: percent,
reverse: true,
)
动画效果
设置 milliseconds
属性来启用动画效果。
RoundedProgressBar(
milliseconds: 1000,
percent: percent,
theme: RoundedProgressBarTheme.yellow,
borderRadius: BorderRadius.circular(24),
)
主题
支持多种预定义的主题:
RoundedProgressBarTheme.blue,
RoundedProgressBarTheme.red,
RoundedProgressBarTheme.green,
RoundedProgressBarTheme.purple,
RoundedProgressBarTheme.yellow,
RoundedProgressBarTheme.midnight
图标圆形进度条
使用 IconRoundedProgressBar
来显示带有图标的圆形进度条。
IconRoundedProgressBar(
icon: Padding(
padding: EdgeInsets.all(8), child: Icon(Icons.person)),
theme: RoundedProgressBarTheme.green,
margin: EdgeInsets.symmetric(vertical: 16),
borderRadius: BorderRadius.circular(6),
percent: percent,
)
自定义背景和图标
自定义背景和图标样式:
IconRoundedProgressBar(
widthIconSection: 70,
icon: Padding(
padding: EdgeInsets.all(8),
child: Icon(Icons.airline_seat_flat, color: Colors.white)),
style: RoundedProgressBarStyle(
colorBackgroundIcon: Color(0xffc0392b),
colorProgress: Color(0xffe74c3c),
colorProgressDark: Color(0xffc0392b),
colorBorder: Color(0xff2c3e50),
backgroundProgress: Color(0xff4a627a),
borderWidth: 4,
widthShadow: 6),
margin: EdgeInsets.symmetric(vertical: 16),
borderRadius: BorderRadius.circular(6),
percent: percent,
)
示例代码
以下是一个完整的示例代码,展示了如何在 Flutter 应用中使用 flutter_rounded_progress_bar
插件:
import 'package:flutter/material.dart';
import 'package:flutter_rounded_progress_bar/flutter_icon_rounded_progress_bar.dart';
import 'package:flutter_rounded_progress_bar/flutter_rounded_progress_bar.dart';
import 'package:flutter_rounded_progress_bar/rounded_progress_bar_style.dart';
void main() => runApp(MyApp());
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
double percent = 10;
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(
title: Text('Rounded Progress Bar'),
actions: <Widget>[
IconButton(
icon: Icon(Icons.add),
onPressed: () {
setState(() {
percent += 5;
});
},
),
IconButton(
icon: Icon(Icons.remove),
onPressed: () {
setState(() {
percent -= 5;
});
},
)
],
),
body: Padding(
padding: EdgeInsets.all(16),
child: Center(
child: ListView(children: <Widget>[
Column(
children: <Widget>[
RoundedProgressBar(
percent: percent, childCenter: Text("$percent%")),
RoundedProgressBar(
childLeft: Text("$percent%",
style: TextStyle(color: Colors.white)),
percent: percent,
theme: RoundedProgressBarTheme.green),
RoundedProgressBar(
childRight: Text("$percent%",
style: TextStyle(color: Colors.white)),
percent: percent,
theme: RoundedProgressBarTheme.red,
reverse: true),
RoundedProgressBar(
percent: percent,
theme: RoundedProgressBarTheme.purple,
childLeft: AnimatedContainer(
padding: EdgeInsets.only(left: 8),
duration: Duration(milliseconds: 500),
child: Icon(
Icons.airplanemode_active,
color: Colors.white,
),
),
paddingChildLeft: EdgeInsets.all(0)),
RoundedProgressBar(
milliseconds: 1000,
percent: percent,
theme: RoundedProgressBarTheme.yellow,
borderRadius: BorderRadius.circular(24)),
RoundedProgressBar(
percent: percent,
height: 70,
theme: RoundedProgressBarTheme.midnight,
childCenter: Text("$percent%",
style: TextStyle(
fontSize: 22,
fontWeight: FontWeight.bold,
color: Colors.yellow))),
RoundedProgressBar(
style: RoundedProgressBarStyle(
widthShadow: 30, colorBorder: Colors.blue[200]!),
percent: percent,
reverse: true,
),
RoundedProgressBar(
style:
RoundedProgressBarStyle(borderWidth: 0, widthShadow: 0),
margin: EdgeInsets.symmetric(vertical: 16),
borderRadius: BorderRadius.circular(24),
percent: percent,
),
IconRoundedProgressBar(
icon: Padding(
padding: EdgeInsets.all(8), child: Icon(Icons.person)),
theme: RoundedProgressBarTheme.green,
margin: EdgeInsets.symmetric(vertical: 16),
borderRadius: BorderRadius.circular(6),
percent: percent,
),
IconRoundedProgressBar(
widthIconSection: 70,
reverse: true,
icon: Padding(
padding: EdgeInsets.all(8),
child:
Icon(Icons.airline_seat_flat, color: Colors.white)),
style: RoundedProgressBarStyle(
colorBackgroundIcon: Color(0xffc0392b),
colorProgress: Color(0xffe74c3c),
colorProgressDark: Color(0xffc0392b),
colorBorder: Color(0xff2c3e50),
backgroundProgress: Color(0xff4a627a),
borderWidth: 4,
widthShadow: 6),
margin: EdgeInsets.symmetric(vertical: 16),
borderRadius: BorderRadius.circular(6),
percent: percent,
),
],
)
]),
),
),
),
);
}
}
通过以上代码,你可以看到如何在 Flutter 应用中使用 flutter_rounded_progress_bar
插件来创建和自定义圆形进度条。希望这对你的项目有所帮助!
更多关于Flutter圆形进度条插件flutter_rounded_progress_bar的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
1 回复