AndroidRate es una biblioteca para ayudarlo a promocionar su aplicación de Android al pedirles a los usuarios que califiquen la aplicación después de usarla durante unos días.
Módulo 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);
}
}
Las condiciones predeterminadas para mostrar el cuadro de diálogo de tasas son las siguientes:
- La aplicación se inicia más de 10 días después de la instalación. Cambiar vía
AppRate#setInstallDays(byte)
.
- La aplicación se lanza más de 10 veces. Cambiar vía
AppRate#setLaunchTimes(byte)
.
- La aplicación se inicia más de 1 día después de hacer clic en el botón neutral. Cambiar vía
AppRate#setRemindInterval(byte)
.
- La aplicación se inicia X veces y X% 1 = 0. Cambiar mediante
AppRate#setRemindLaunchTimes(byte)
.
- La aplicación muestra un cuadro de diálogo neutral (Recordármelo más tarde) de forma predeterminada. Cambiar vía
setShowLaterButton(boolean)
.
- Para especificar la devolución de llamada cuando se presiona el botón. Se
DialogInterface.OnClickListener#onClick
pasará el mismo valor que el segundo argumento de en el argumento de onClickButton
.
- La configuración
AppRate#setDebug(boolean)
garantizará que la solicitud de calificación se muestre cada vez que se inicia la aplicación. ¡Esta característica es solo para desarrollo! .
Requisitos de eventos personalizados opcionales para mostrar el diálogo
Puede agregar requisitos opcionales adicionales para mostrar el diálogo. Cada requisito se puede agregar / referenciar como una cadena única. Puede establecer un recuento mínimo para cada uno de estos eventos (por ejemplo, "action_performed" 3 veces, "button_clicked" 5 veces, etc.)
AppRate.with(this).setMinimumEventCount(String, short);
AppRate.with(this).incrementEventCount(String);
AppRate.with(this).setEventCountValue(String, short);
Borrar el indicador de diálogo de mostrar
Cuando desee volver a mostrar el cuadro de diálogo, llame AppRate#clearAgreeShowDialog()
.
AppRate.with(this).clearAgreeShowDialog();
Cuando el botón presiona
llamar AppRate#showRateDialog(Activity)
.
AppRate.with(this).showRateDialog(this);
Establecer vista personalizada
llamar 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();
Tema específico
Puede utilizar un tema específico para inflar el diálogo.
AppRate.with(this).setThemeResId(int);
Diálogo personalizado
Si desea utilizar sus propias etiquetas de diálogo, anule los recursos xml de cadena en su aplicación.
<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>
Comprueba que Google Play esté disponible
if (GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(this) != ConnectionResult.SERVICE_MISSING) {
}