Dopo aver registrato un recinto, l'app deve aggiungerne uno per rispondere
quando viene attivata. Per farlo, puoi utilizzare una sottoclasse
BroadcastReceiver
per gestire i metodi Intent
dalle recinzioni.
Per poter aggiungere callback a un recinto, devi prima registrarlo.
Creare una sottoclasse BroadcastRicezioner
L'esempio seguente mostra la classe FenceReceiver
, che si estende per BroadcastReceiver
. La classe implementa il metodo di callback BroadcastReceiver.onReceive()
per gestire tutti i metodi Intent
che hanno origine dai recinzioni creati dalla tua app. Quando viene ricevuto un metodo Intent
, viene utilizzato il metodo FenceState.extract()
per ottenere lo stato del recinto e passarlo al callback.
public class FenceReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
FenceState fenceState = FenceState.extract(intent);
if (TextUtils.equals(fenceState.getFenceKey(), FENCE_KEY)) {
String fenceStateStr;
switch (fenceState.getCurrentState()) {
case FenceState.TRUE:
fenceStateStr = "true";
break;
case FenceState.FALSE:
fenceStateStr = "false";
break;
case FenceState.UNKNOWN:
fenceStateStr = "unknown";
break;
default:
fenceStateStr = "unknown value";
}
mLogFragment.getLogView().println("Fence state: " + fenceStateStr);
}
}
}