Flutter星级评分插件star_rating的使用
Flutter星级评分插件star_rating的使用
flutter_star_raiting
是一个可定制的Flutter小部件,用于以星形进行评分。您可以设置颜色、大小、数量和星星之间的间距。
示例
示例代码
下面是一个完整的示例 demo
,展示了如何在Flutter应用中使用 star_rating
插件。
main.dart
import 'package:flutter/material.dart';
import 'package:star_rating/star_rating.dart';
void main() => runApp(const StarRatingDemo());
class StarRatingDemo extends StatelessWidget {
const StarRatingDemo({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Star Rating Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const MyHomePage(title: 'Star Rating Demo Home Page'),
debugShowCheckedModeBanner: false,
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({required this.title, super.key});
final String title;
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
final int starLength = 7;
double _rating = 0;
void _incrementHalfStar() {
setState(() {
_rating += 0.5;
if (_rating > starLength) {
_rating = starLength.toDouble();
}
});
}
void _decrementHalfStar() {
setState(() {
_rating -= 0.5;
if (_rating < 0.0) {
_rating = 0.0;
}
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Star Rating Example'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Text(
'Rating: $_rating / ${starLength.toDouble()}',
style: Theme.of(context).textTheme.headlineMedium,
),
StarRating(
mainAxisAlignment: MainAxisAlignment.center,
length: starLength,
rating: _rating,
between: 5,
starSize: 30,
onRaitingTap: (rating) {
print('Clicked rating: $rating / $starLength');
setState(() {
_rating = rating;
});
},
),
],
),
),
floatingActionButton: Column(
crossAxisAlignment: CrossAxisAlignment.end,
mainAxisAlignment: MainAxisAlignment.end,
children: <Widget>[
FloatingActionButton(
onPressed: _incrementHalfStar,
tooltip: 'Increment',
child: const Icon(Icons.arrow_drop_up),
),
FloatingActionButton(
onPressed: _decrementHalfStar,
tooltip: 'Decrement',
child: const Icon(Icons.arrow_drop_down),
),
],
),
);
}
}
解释
-
导入依赖:首先确保在
pubspec.yaml
文件中添加了star_rating
依赖:dependencies: flutter: sdk: flutter star_rating: ^x.x.x # 使用最新版本
-
主函数:定义了一个简单的
main
函数来启动应用。 -
主页组件:
MyHomePage
组件包含状态_rating
和一些方法来增加或减少评分。 -
星形评分组件:
StarRating
小部件允许用户点击星星来评分,并且可以自定义星星的数量、大小和间距等属性。 -
浮动按钮:两个浮动按钮分别用来增加和减少评分。
通过上述步骤,您可以在Flutter应用中轻松实现星级评分功能。希望这个示例对您有所帮助!
更多关于Flutter星级评分插件star_rating的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter星级评分插件star_rating的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
当然,以下是如何在Flutter项目中使用star_rating
插件来实现星级评分功能的代码案例。star_rating
插件允许你轻松地在应用中添加星级评分组件。
首先,你需要在pubspec.yaml
文件中添加star_rating
依赖:
dependencies:
flutter:
sdk: flutter
star_rating: ^1.0.0 # 请确保使用最新版本
然后,运行flutter pub get
来获取依赖包。
接下来,在你的Dart文件中(例如main.dart
),你可以按照以下方式使用StarRating
组件:
import 'package:flutter/material.dart';
import 'package:star_rating/star_rating.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Star Rating Example',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: StarRatingScreen(),
);
}
}
class StarRatingScreen extends StatefulWidget {
@override
_StarRatingScreenState createState() => _StarRatingScreenState();
}
class _StarRatingScreenState extends State<StarRatingScreen> {
double _rating = 0.0;
void _onRatingChanged(double rating) {
setState(() {
_rating = rating;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Star Rating Example'),
),
body: Padding(
padding: const EdgeInsets.all(16.0),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Text('Current Rating: ${_rating.toStringAsFixed(1)}'),
SizedBox(height: 20.0),
StarRating(
rating: _rating,
starCount: 5,
starSize: 40.0,
color: Colors.amber,
borderColor: Colors.grey,
spacing: 5.0,
onRatingChanged: _onRatingChanged,
),
],
),
),
);
}
}
在这个示例中,我们创建了一个简单的Flutter应用,其中包含一个星级评分组件。以下是代码的关键部分:
- 依赖引入:在
pubspec.yaml
文件中添加了star_rating
依赖。 - StarRating组件:
rating
:当前评分值。starCount
:星星的数量,这里设置为5。starSize
:星星的大小。color
:星星被选中时的颜色。borderColor
:星星边框的颜色。spacing
:星星之间的间距。onRatingChanged
:当评分改变时的回调函数。
当用户点击星星时,_onRatingChanged
函数会被调用,并更新当前评分值。
确保你已经正确安装并运行了Flutter环境,并且star_rating
插件的版本是最新的,以避免任何兼容性问题。