Flutter星级评分插件star_rating的使用

发布于 1周前 作者 caililin 来自 Flutter

Flutter星级评分插件star_rating的使用

flutter_star_raiting 是一个可定制的Flutter小部件,用于以星形进行评分。您可以设置颜色、大小、数量和星星之间的间距。

示例

Flutter star rating

示例代码

下面是一个完整的示例 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),
          ),
        ],
      ),
    );
  }
}

解释

  1. 导入依赖:首先确保在 pubspec.yaml 文件中添加了 star_rating 依赖:

    dependencies:
      flutter:
        sdk: flutter
      star_rating: ^x.x.x # 使用最新版本
    
  2. 主函数:定义了一个简单的 main 函数来启动应用。

  3. 主页组件MyHomePage 组件包含状态 _rating 和一些方法来增加或减少评分。

  4. 星形评分组件StarRating 小部件允许用户点击星星来评分,并且可以自定义星星的数量、大小和间距等属性。

  5. 浮动按钮:两个浮动按钮分别用来增加和减少评分。

通过上述步骤,您可以在Flutter应用中轻松实现星级评分功能。希望这个示例对您有所帮助!


更多关于Flutter星级评分插件star_rating的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于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应用,其中包含一个星级评分组件。以下是代码的关键部分:

  1. 依赖引入:在pubspec.yaml文件中添加了star_rating依赖。
  2. StarRating组件
    • rating:当前评分值。
    • starCount:星星的数量,这里设置为5。
    • starSize:星星的大小。
    • color:星星被选中时的颜色。
    • borderColor:星星边框的颜色。
    • spacing:星星之间的间距。
    • onRatingChanged:当评分改变时的回调函数。

当用户点击星星时,_onRatingChanged函数会被调用,并更新当前评分值。

确保你已经正确安装并运行了Flutter环境,并且star_rating插件的版本是最新的,以避免任何兼容性问题。

回到顶部