Flutter如何实现rate_my_app评分功能

在Flutter项目中,我想集成一个类似rate_my_app的评分功能,让用户可以对应用进行评分和反馈。目前遇到几个问题:

  1. 如何正确配置Android和iOS平台的跳转商店链接?
  2. 评分弹窗的触发条件该怎么设置(比如使用次数或天数)?
  3. 是否有办法自定义弹窗的样式和文案?
  4. 用户点击“不再提醒”后如何持久化存储这个状态?
    希望有经验的大佬能分享一下具体实现步骤或注意事项!
2 回复

使用rate_my_app插件。在pubspec.yaml添加依赖,初始化后调用RateMyApp().showStarRateDialog()显示评分弹窗。可配置触发条件,如启动次数或使用天数。

更多关于Flutter如何实现rate_my_app评分功能的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


在Flutter中实现应用评分功能,推荐使用 rate_my_app 第三方库。以下是具体实现步骤:

1. 添加依赖

pubspec.yaml 中:

dependencies:
  rate_my_app: ^1.1.0

2. 基本配置

import 'package:rate_my_app/rate_my_app.dart';

RateMyApp rateMyApp = RateMyApp(
  preferencesPrefix: 'rateMyApp_',
  minDays: 7,       // 至少使用7天后提示
  minLaunches: 10,  // 至少启动10次后提示
  remindDays: 7,    // 用户点击"稍后"后,7天后再提示
  remindLaunches: 10,
);

3. 初始化与显示

initState() 中初始化:

@override
void initState() {
  super.initState();
  rateMyApp.init().then((_) {
    if (rateMyApp.shouldOpenDialog) {
      rateMyApp.showStarRateDialog(
        context,
        title: '喜欢这个应用吗?',
        message: '请给我们评分支持!',
        actionsBuilder: (_, stars) {
          return [
            TextButton(
              child: Text('取消'),
              onPressed: () => Navigator.pop(context),
            ),
            TextButton(
              child: Text('提交'),
              onPressed: () {
                if (stars != null) {
                  rateMyApp.callEvent(RateMyAppEventType.rateButtonPressed);
                  // 跳转到应用商店
                  rateMyApp.launchStore();
                }
                Navigator.pop(context);
              },
            ),
          ];
        },
        starRatingOptions: StarRatingOptions(), // 自定义星级选项
      );
    }
  });
}

4. 完整示例

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  RateMyApp rateMyApp = RateMyApp(
    preferencesPrefix: 'rateMyApp_',
    minDays: 7,
    minLaunches: 10,
    remindDays: 7,
    remindLaunches: 10,
  );

  @override
  void initState() {
    super.initState();
    rateMyApp.init().then((_) {
      if (rateMyApp.shouldOpenDialog) {
        rateMyApp.showStarRateDialog(
          context,
          title: '为应用评分',
          message: '您的支持对我们很重要!',
          actionsBuilder: (_, stars) => [
            TextButton(
              onPressed: () => Navigator.pop(context),
              child: Text('取消'),
            ),
            TextButton(
              onPressed: () {
                if (stars != null) {
                  rateMyApp.launchStore();
                }
                Navigator.pop(context);
              },
              child: Text('提交'),
            ),
          ],
        );
      }
    });
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: Text('评分示例')),
        body: Center(child: Text('应用内容')),
      ),
    );
  }
}

5. 高级配置

  • 可自定义对话框样式
  • 支持条件触发(如完成特定任务后)
  • 支持iOS和Android不同商店
  • 可设置不重复提示

注意事项

  • 测试时可将 minDaysminLaunches 设为0
  • 真实发布前恢复为合理数值
  • 遵守各平台评分指南

这样即可实现一个符合应用商店政策、用户体验良好的评分功能。

回到顶部