AndroidRate è una libreria che ti aiuta a promuovere la tua app Android chiedendo agli utenti di valutare l'app dopo averla utilizzata per alcuni giorni.
Modulo 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);
}
}
Le condizioni predefinite per mostrare la finestra di dialogo del tasso sono le seguenti:
- L'app viene avviata più di 10 giorni dopo l'installazione. Cambia via
AppRate#setInstallDays(byte)
.
- L'app viene lanciata più di 10 volte. Cambia via
AppRate#setLaunchTimes(byte)
.
- L'app viene avviata più di 1 giorni dopo aver fatto clic sul pulsante neutro. Cambia via
AppRate#setRemindInterval(byte)
.
- L'app viene avviata X volte e X% 1 = 0. Modifica tramite
AppRate#setRemindLaunchTimes(byte)
.
- L'app mostra una finestra di dialogo neutra (ricordamelo più tardi) per impostazione predefinita. Cambia via
setShowLaterButton(boolean)
.
- Per specificare la richiamata quando si preme il pulsante. Lo stesso valore del secondo argomento di
DialogInterface.OnClickListener#onClick
verrà passato nell'argomento di onClickButton
.
- L'impostazione
AppRate#setDebug(boolean)
garantirà che la richiesta di valutazione venga visualizzata ogni volta che l'app viene avviata. Questa funzione è solo per lo sviluppo! .
Requisiti evento personalizzati opzionali per la visualizzazione della finestra di dialogo
È possibile aggiungere ulteriori requisiti opzionali per la visualizzazione della finestra di dialogo. Ogni requisito può essere aggiunto / referenziato come una stringa univoca. Puoi impostare un conteggio minimo per ciascuno di questi eventi (ad esempio "action_performed" 3 volte, "button_clicked" 5 volte, ecc.)
AppRate.with(this).setMinimumEventCount(String, short);
AppRate.with(this).incrementEventCount(String);
AppRate.with(this).setEventCountValue(String, short);
Cancella il flag della finestra di dialogo dello spettacolo
Quando vuoi mostrare di nuovo la finestra di dialogo, chiama AppRate#clearAgreeShowDialog()
.
AppRate.with(this).clearAgreeShowDialog();
Quando il pulsante preme
chiamare AppRate#showRateDialog(Activity)
.
AppRate.with(this).showRateDialog(this);
Imposta visualizzazione personalizzata
chiamare 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 specifico
Puoi usare un tema specifico per gonfiare la finestra di dialogo.
AppRate.with(this).setThemeResId(int);
Finestra di dialogo personalizzata
Se desideri utilizzare le tue etichette di dialogo, sovrascrivi le risorse xml della stringa nell'applicazione.
<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>
Verifica che Google Play sia disponibile
if (GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(this) != ConnectionResult.SERVICE_MISSING) {
}