谷歌播放 - 如何在Android应用程序中实现Rate It功能

我正在开发一个Android应用程序。 其中一切正常。 我的应用已准备好发布。 但我需要再实现一个功能。 我需要显示一个包含的弹出窗口

Rate ItRemind me later

如果有任何用户对市场中的应用进行评级,则弹出窗口不会消失。我在谷歌搜索过,发现了一个链接。 有了这个,我明白它不可能知道。 所以我需要一个建议。

以前有人遇到过这种情况吗? 如果是这样,是否有任何解决方案或任何替代方案?

Naveen asked 2019-09-17T07:55:36Z
9个解决方案
153 votes

我在一段时间内实现了这一点。 不可能知道用户是否对应用程序进行了评级,以防止评级成为一种货币(一些开发人员可能会添加一个选项,如“评价此应用程序并在应用程序中免费获取”)。

我编写的类提供了三个按钮,并配置对话框,使其仅在应用程序启动后显示n次(如果用户之前使用过它,用户有更高的评级应用程序的机会。大多数是 甚至不太可能知道它在第一次运行时的作用):

public class AppRater {
    private final static String APP_TITLE = "App Name";// App Name
    private final static String APP_PNAME = "com.example.name";// Package Name

    private final static int DAYS_UNTIL_PROMPT = 3;//Min number of days
    private final static int LAUNCHES_UNTIL_PROMPT = 3;//Min number of launches

    public static void app_launched(Context mContext) {
        SharedPreferences prefs = mContext.getSharedPreferences("apprater", 0);
        if (prefs.getBoolean("dontshowagain", false)) { return ; }

        SharedPreferences.Editor editor = prefs.edit();

        // Increment launch counter
        long launch_count = prefs.getLong("launch_count", 0) + 1;
        editor.putLong("launch_count", launch_count);

        // Get date of first launch
        Long date_firstLaunch = prefs.getLong("date_firstlaunch", 0);
        if (date_firstLaunch == 0) {
            date_firstLaunch = System.currentTimeMillis();
            editor.putLong("date_firstlaunch", date_firstLaunch);
        }

        // Wait at least n days before opening
        if (launch_count >= LAUNCHES_UNTIL_PROMPT) {
            if (System.currentTimeMillis() >= date_firstLaunch + 
                    (DAYS_UNTIL_PROMPT * 24 * 60 * 60 * 1000)) {
                showRateDialog(mContext, editor);
            }
        }

        editor.commit();
    }   

    public static void showRateDialog(final Context mContext, final SharedPreferences.Editor editor) {
        final Dialog dialog = new Dialog(mContext);
        dialog.setTitle("Rate " + APP_TITLE);

        LinearLayout ll = new LinearLayout(mContext);
        ll.setOrientation(LinearLayout.VERTICAL);

        TextView tv = new TextView(mContext);
        tv.setText("If you enjoy using " + APP_TITLE + ", please take a moment to rate it. Thanks for your support!");
        tv.setWidth(240);
        tv.setPadding(4, 0, 4, 10);
        ll.addView(tv);

        Button b1 = new Button(mContext);
        b1.setText("Rate " + APP_TITLE);
        b1.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                mContext.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + APP_PNAME)));
                dialog.dismiss();
            }
        });        
        ll.addView(b1);

        Button b2 = new Button(mContext);
        b2.setText("Remind me later");
        b2.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                dialog.dismiss();
            }
        });
        ll.addView(b2);

        Button b3 = new Button(mContext);
        b3.setText("No, thanks");
        b3.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                if (editor != null) {
                    editor.putBoolean("dontshowagain", true);
                    editor.commit();
                }
                dialog.dismiss();
            }
        });
        ll.addView(b3);

        dialog.setContentView(ll);        
        dialog.show();        
    }
}

集成类就像添加:

AppRater.app_launched(this);

致你的活动。 它只需要添加到整个应用程序中的一个Activity。

Raghav Sood answered 2019-09-17T07:56:18Z
32 votes

我用这个:[https://github.com/kskkbys/Android-RateThisApp] - 很好,有点不引人注意的行为。RateThisApp screenshot from kskkbys

saschoar answered 2019-09-17T07:56:48Z
15 votes

我使用DialogFragment:

public class RateItDialogFragment extends DialogFragment {
    private static final int LAUNCHES_UNTIL_PROMPT = 10;
    private static final int DAYS_UNTIL_PROMPT = 3;
    private static final int MILLIS_UNTIL_PROMPT = DAYS_UNTIL_PROMPT * 24 * 60 * 60 * 1000;
    private static final String PREF_NAME = "APP_RATER";
    private static final String LAST_PROMPT = "LAST_PROMPT";
    private static final String LAUNCHES = "LAUNCHES";
    private static final String DISABLED = "DISABLED";

    public static void show(Context context, FragmentManager fragmentManager) {
        boolean shouldShow = false;
        SharedPreferences sharedPreferences = getSharedPreferences(context);
        SharedPreferences.Editor editor = sharedPreferences.edit();
        long currentTime = System.currentTimeMillis();
        long lastPromptTime = sharedPreferences.getLong(LAST_PROMPT, 0);
        if (lastPromptTime == 0) {
            lastPromptTime = currentTime;
            editor.putLong(LAST_PROMPT, lastPromptTime);
        }

        if (!sharedPreferences.getBoolean(DISABLED, false)) {
            int launches = sharedPreferences.getInt(LAUNCHES, 0) + 1;
            if (launches > LAUNCHES_UNTIL_PROMPT) {
                if (currentTime > lastPromptTime + MILLIS_UNTIL_PROMPT) {
                    shouldShow = true;
                }
            }
            editor.putInt(LAUNCHES, launches);
        }

        if (shouldShow) {
            editor.putInt(LAUNCHES, 0).putLong(LAST_PROMPT, System.currentTimeMillis()).commit();
            new RateItDialogFragment().show(fragmentManager, null);
        } else {
            editor.commit();
        }
    }

    private static SharedPreferences getSharedPreferences(Context context) {
        return context.getSharedPreferences(PREF_NAME, 0);
    }

    @Override
    public Dialog onCreateDialog(Bundle savedInstanceState) {
        return new AlertDialog.Builder(getActivity())
                .setTitle(R.string.rate_title)
                .setMessage(R.string.rate_message)
                .setPositiveButton(R.string.rate_positive, new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + getActivity().getPackageName())));
                        getSharedPreferences(getActivity()).edit().putBoolean(DISABLED, true).commit();
                        dismiss();
                    }
                })
                .setNeutralButton(R.string.rate_remind_later, new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        dismiss();
                    }
                })
                .setNegativeButton(R.string.rate_never, new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        getSharedPreferences(getActivity()).edit().putBoolean(DISABLED, true).commit();
                        dismiss();
                    }
                }).create();
    }
}

然后在主FragmentActivity的onCreate()中使用它:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ...

    RateItDialogFragment.show(this, getFragmentManager());

}
mixel answered 2019-09-17T07:57:19Z
6 votes

我认为你要做的事情可能适得其反。

让人们轻松评价应用程序通常是一个好主意,因为大多数人都喜欢这样做,因为他们喜欢这个应用程序。 据传,评级数量会影响您的市场评级(尽管我看不到这方面的证据)。 通过唠叨屏幕对用户进行评级可能会导致人们通过留下糟糕的评级来清除唠叨。

添加直接评价应用程序的功能导致我的免费版本的数字评级略有下降,并且我的付费应用程序略有增加。 对于免费的应用程序,我的4星评级增加超过我的5星评级,因为那些认为我的应用程序很好但不是很好的人开始评价它。 变化约为-0.2。 对于付费,变化约为+0.1。 我应该从免费版本中删除它,除了我喜欢收到很多评论。

我将我的评级按钮放入设置(首选项)屏幕,它不会影响正常操作。 它仍然将我的评级率提高了4或5倍。我毫不怀疑,如果我试图唠叨我的用户进行评级,我会让很多用户给我评价不好作为抗议。

Peter Webb answered 2019-09-17T07:58:07Z
4 votes

AndroidRate是一个帮助您推广Android应用程序的库,它提示用户在使用该应用程序几天后对其进行评级。

模块Gradle:

dependencies {
  implementation 'com.vorlonsoft:androidrate:1.0.8'
}

MainActivity.java:

@Override
protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);

  AppRate.with(this)
      .setStoreType(StoreType.GOOGLEPLAY) //default is GOOGLEPLAY (Google Play), other options are
                                          //           AMAZON (Amazon Appstore) and
                                          //           SAMSUNG (Samsung Galaxy Apps)
      .setInstallDays((byte) 0) // default 10, 0 means install day
      .setLaunchTimes((byte) 3) // default 10
      .setRemindInterval((byte) 2) // default 1
      .setRemindLaunchTimes((byte) 2) // default 1 (each launch)
      .setShowLaterButton(true) // default true
      .setDebug(false) // default false
      //Java 8+: .setOnClickButtonListener(which -> Log.d(MainActivity.class.getName(), Byte.toString(which)))
      .setOnClickButtonListener(new OnClickButtonListener() { // callback listener.
          @Override
          public void onClickButton(byte which) {
              Log.d(MainActivity.class.getName(), Byte.toString(which));
          }
      })
      .monitor();

  if (AppRate.with(this).getStoreType() == StoreType.GOOGLEPLAY) {
      //Check that Google Play is available
      if (GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(this) != ConnectionResult.SERVICE_MISSING) {
          // Show a dialog if meets conditions
          AppRate.showRateDialogIfMeetsConditions(this);
      }
  } else {
      // Show a dialog if meets conditions
      AppRate.showRateDialogIfMeetsConditions(this);
  }
}

显示速率对话框的默认条件如下:

  1. 应用程序比安装后晚10天启动。 通过AppRate#setView(View)进行更改。
  2. App推出了10多次。 通过AppRate#setView(View)进行更改。
  3. 点击中性按钮后,应用程序启动超过1天。 通过AppRate#setView(View)进行更改。
  4. 应用程序启动X次,X%1 = 0.通过AppRate#setView(View)更改。
  5. 应用程序默认显示中性对话框(稍后提醒我)。 通过AppRate#setView(View)进行更改。
  6. 按下按钮时指定回调。 与AppRate#setView(View)的第二个参数相同的值将在onClickButton的参数中传递。
  7. 设置AppRate#setView(View)将确保每次启动应用程序时都会显示评级请求。 此功能仅用于开发!

用于显示对话框的可选自定义事件要

您可以添加其他可选要求以显示对话框。 每个需求都可以作为唯一字符串添加/引用。 您可以为每个此类事件设置最小计数(例如,“action_performed”3次,“button_clicked”5次等)

AppRate.with(this).setMinimumEventCount(String, short);
AppRate.with(this).incrementEventCount(String);
AppRate.with(this).setEventCountValue(String, short);

清除显示对话框标志

如果要再次显示该对话框,请致电AppRate#setView(View)

AppRate.with(this).clearAgreeShowDialog();

当按钮按下时

请致电AppRate#setView(View)

AppRate.with(this).showRateDialog(this);

设置自定义视图

请致电AppRate#setView(View)

LayoutInflater inflater = (LayoutInflater)this.getSystemService(LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.custom_dialog, (ViewGroup)findViewById(R.id.layout_root));
AppRate.with(this).setView(view).monitor();

具体主题

您可以使用特定主题来扩充对话框。

AppRate.with(this).setThemeResId(int);

定制对话框

如果要使用自己的对话框标签,请覆盖应用程序上的字符串xml资源。

<resources>
    <string name="rate_dialog_title">Rate this app</string>
    <string name="rate_dialog_message">If you enjoy playing this app, would you mind taking a moment to rate it? It won\'t take more than a minute. Thanks for your support!</string>
    <string name="rate_dialog_ok">Rate It Now</string>
    <string name="rate_dialog_cancel">Remind Me Later</string>
    <string name="rate_dialog_no">No, Thanks</string>
</resources>

检查Google Play是否可用

if (GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(this) != ConnectionResult.SERVICE_MISSING) {

}
Alexander Savin answered 2019-09-17T08:00:57Z
3 votes

使用这个库,简单易用..[https://github.com/hotchemi/Android-Rate]

通过添加依赖..

dependencies {
  compile 'com.github.hotchemi:android-rate:0.5.6'
}
shaiban answered 2019-09-17T08:01:29Z
2 votes

我正在使用这个简单的解决方案。您可以使用gradle添加此库:[https://github.com/fernandodev/easy-rating-dialog]

compile 'com.github.fernandodev.easyratingdialog:easyratingdialog:+'
Fernando Martínez answered 2019-09-17T08:01:54Z
2 votes

该解决方案与上面提出的解决方案非常相似。 唯一的区别是,您将能够在每次启动和日期延迟评级对话框的提示。 如果按下提醒我按钮,那么我将延迟弹出3天和10次发布。 对于那些选择对其进行评级的人来说也是如此,但是延迟时间更长(如果他实际上已经对应用程序进行了评级,那么不要太快打扰用户。这可以改为不再显示,那么你将不得不 改变你喜欢的代码)。 希望它能帮助别人!

public class AppRater {
    private final static String APP_TITLE = "your_app_name";
    private static String PACKAGE_NAME = "your_package_name";
    private static int DAYS_UNTIL_PROMPT = 5;
    private static int LAUNCHES_UNTIL_PROMPT = 10;
    private static long EXTRA_DAYS;
    private static long EXTRA_LAUCHES;
    private static SharedPreferences prefs;
    private static SharedPreferences.Editor editor;
    private static Activity activity;

    public static void app_launched(Activity activity1) {
        activity = activity1;

        Configs.sendScreenView("Avaliando App", activity);

        PACKAGE_NAME = activity.getPackageName();

        prefs = activity.getSharedPreferences("apprater", Context.MODE_PRIVATE);
        if (prefs.getBoolean("dontshowagain", false)) 
            return;

        editor = prefs.edit();

        EXTRA_DAYS = prefs.getLong("extra_days", 0);
        EXTRA_LAUCHES = prefs.getLong("extra_launches", 0);

        // Increment launch counter
        long launch_count = prefs.getLong("launch_count", 0) + 1;
        editor.putLong("launch_count", launch_count);

        // Get date of first launch
        Long date_firstLaunch = prefs.getLong("date_firstlaunch", 0);
        if (date_firstLaunch == 0) {
            date_firstLaunch = System.currentTimeMillis();
            editor.putLong("date_firstlaunch", date_firstLaunch);
        }

        // Wait at least n days before opening
        if (launch_count >= (LAUNCHES_UNTIL_PROMPT + EXTRA_LAUCHES))
            if (System.currentTimeMillis() >= date_firstLaunch + (DAYS_UNTIL_PROMPT * 24 * 60 * 60 * 1000) + EXTRA_DAYS)
                showRateDialog();

        editor.commit();
    }   

    public static void showRateDialog() {
        final Dialog dialog = new Dialog(activity);
        dialog.setTitle("Deseja avaliar o aplicativo " + APP_TITLE + "?");

        LinearLayout ll = new LinearLayout(activity);
        ll.setOrientation(LinearLayout.VERTICAL);
        ll.setPadding(5, 5, 5, 5);

        TextView tv = new TextView(activity);
        tv.setTextColor(activity.getResources().getColor(R.color.default_text));
        tv.setText("Ajude-nos a melhorar o aplicativo com sua avaliação no Google Play!");
        tv.setWidth(240);
        tv.setGravity(Gravity.CENTER);
        tv.setPadding(5, 5, 5, 5);
        ll.addView(tv);

        Button b1 = new Button(activity);
        b1.setTextColor(activity.getResources().getColor(R.color.default_text));
        b1.setBackground(activity.getResources().getDrawable(R.drawable.rounded_blue_box));
        b1.setTextColor(Color.WHITE);
        b1.setText("Avaliar aplicativo " + APP_TITLE + "!");
        b1.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                Configs.sendHitEvents(Configs.APP_RATER, Configs.CATEGORIA_ANALYTICS, "Clique", "Avaliar", activity);

                activity.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=" + PACKAGE_NAME)));
                delayDays(60);
                delayLaunches(30);
                dialog.dismiss();
            }
        });        
        ll.addView(b1);
        LinearLayout.LayoutParams params = (LinearLayout.LayoutParams) b1.getLayoutParams();
        params.setMargins(5, 3, 5, 3);
        b1.setLayoutParams(params);

        Button b2 = new Button(activity);
        b2.setTextColor(activity.getResources().getColor(R.color.default_text));
        b2.setBackground(activity.getResources().getDrawable(R.drawable.rounded_blue_box));
        b2.setTextColor(Color.WHITE);
        b2.setText("Lembre-me mais tarde!");
        b2.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                Configs.sendHitEvents(Configs.APP_RATER, Configs.CATEGORIA_ANALYTICS, "Clique", "Avaliar Mais Tarde", activity);
                delayDays(3);
                delayLaunches(10);
                dialog.dismiss();
            }
        });
        ll.addView(b2);
        params = (LinearLayout.LayoutParams) b2.getLayoutParams();
        params.setMargins(5, 3, 5, 3);
        b2.setLayoutParams(params);

        Button b3 = new Button(activity);
        b3.setTextColor(activity.getResources().getColor(R.color.default_text));
        b3.setBackground(activity.getResources().getDrawable(R.drawable.rounded_blue_box));
        b3.setTextColor(Color.WHITE);
        b3.setText("Não, obrigado!");
        b3.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                Configs.sendHitEvents(Configs.APP_RATER, Configs.CATEGORIA_ANALYTICS, "Clique", "Não Avaliar", activity);

                if (editor != null) {
                    editor.putBoolean("dontshowagain", true);
                    editor.commit();
                }
                dialog.dismiss();
            }
        });
        ll.addView(b3);
        params = (LinearLayout.LayoutParams) b3.getLayoutParams();
        params.setMargins(5, 3, 5, 0);
        b3.setLayoutParams(params);

        dialog.setContentView(ll);        
        dialog.show();        
    }

    private static void delayLaunches(int numberOfLaunches) {
        long extra_launches = prefs.getLong("extra_launches", 0) + numberOfLaunches;
        editor.putLong("extra_launches", extra_launches);
        editor.commit();
    }

    private static void delayDays(int numberOfDays) {
        Long extra_days = prefs.getLong("extra_days", 0) + (numberOfDays * 1000 * 60 * 60 * 24);
        editor.putLong("extra_days", extra_days);
        editor.commit();
    }
}

按钮具有特定的颜色和背景。 背景如下xml文件所示:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:padding="10dp"
    android:shape="rectangle" >

    <solid android:color="#2E78B9" />

    <corners
        android:bottomLeftRadius="6dp"
        android:bottomRightRadius="6dp"
        android:topLeftRadius="6dp"
        android:topRightRadius="6dp" />

</shape>

来源:针对“评价我的应用程序”的Android方法

Gustavo Baiocchi Costa answered 2019-09-17T08:02:34Z
1 votes

从您链接的其他帖子中可以看出,应用无法知道用户是否已经离开了评论。 并且有充分的理由。

考虑一下,如果应用程序可以判断用户是否已经离开了评论,开发人员可以限制某些功能,这些功能只有在用户离开5/5评级时才会解锁。 这将导致Google Play的其他用户不信任评论,并会破坏评级系统。

我看到的替代解决方案是app会提醒用户在应用程序打开特定次数或设置间隔时提交评级。 例如,应用程序每打开一次,请让用户留下评级并提供“已完成”和“稍后提醒我”按钮。 如果用户选择稍后提醒他/她,请继续显示此消息。 其他一些应用程序开发人员显示此消息的间隔越来越大(例如,打开应用程序的时间是5,10,15),因为如果用户没有在应用程序打开的第100次上留下评论,那么 可能他/她不会离开一个。

这个解决方案并不完美,但我认为这是目前最好的解决方案。 它确实引导您信任用户,但意识到替代方案对于应用市场中的每个人来说都意味着更糟糕的体验。

Vidhur Vohra answered 2019-09-17T08:03:21Z
translate from https://stackoverflow.com:/questions/14514579/how-to-implement-rate-it-feature-in-android-app