Обзор API забора

В API Awareness концепция ограждений взята из geofencing , в котором определяется географический регион или geofence , и приложение получает обратные вызовы, когда пользователь входит в регион geofence или покидает его. API Fence расширяет концепцию geofencing, чтобы включить множество других условий контекста в дополнение к географической близости. Приложение получает обратные вызовы всякий раз, когда состояние контекста меняется. Например, если ваше приложение определяет ограждение для наушников, оно получает обратные вызовы, когда наушники подключены и когда они отключены.

Вы можете использовать API Fence для определения ограждений на основе контекстных сигналов, таких как следующие:

  • Текущее местоположение пользователя (широта/долгота)
  • Текущая активность пользователя, например ходьба или вождение.
  • Условия, характерные для устройства, например, подключены ли наушники.
  • Близость к ближайшим маякам

API Fence позволяет вам объединять несколько контекстных сигналов для создания ограждений с помощью булевых операторов AND , OR и NOT . Затем ваше приложение получает обратные вызовы всякий раз, когда выполняются условия ограждения. Вот некоторые примеры возможных ограждений:

  • Пользователь подключает наушники и начинает идти.
  • Пользователь входит в 100-метровую геозону до 17:00 в будний день.
  • Пользователь вводит радиус действия определенного маяка BLE.

В следующем примере показано, как определить ограждение, которое активируется всякий раз, когда пользователь идет:

AwarenessFence walkingFence = DetectedActivityFence.during(DetectedActivityFence.WALKING);

После того, как вы определили ограждение, вам необходимо сделать следующее:

  • Позвоните в updateFences , чтобы зарегистрировать ограждение для получения обратных вызовов.
  • Определите обратный вызов, который может быть вызван при изменении состояния ограждения.

Следующий пример показывает метод, который создает и регистрирует ограждение. В этом примере пользовательский подкласс BroadcastReceiver используется для обработки намерения при срабатывании ограждения.

Awareness.getFenceClient(this).updateFences(new FenceUpdateRequest.Builder()
    .addFence(FENCE_KEY, exercisingWithHeadphonesFence, mPendingIntent)
    .build())
    .addOnSuccessListener(new OnSuccessListener<Void>() {
        @Override
        public void onSuccess(Void aVoid) {
            Log.i(TAG, "Fence was successfully registered.");
        }
    })
    .addOnFailureListener(new OnFailureListener() {
        @Override
        public void onFailure(@NonNull Exception e) {
            Log.e(TAG, "Fence could not be registered: " + e);
        }
    });
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);
        }
    }
}