Gestire i callback di recinzione

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);
        }
    }
}