Na API Awareness, o conceito de cercas é retirado de geofencing, em que uma região geográfica ou geofence é definida, e um app recebe callbacks quando um usuário entra ou sai da região de fronteira geográfica virtual. A API Fence amplia o conceito de fronteira virtual para incluir muitas outras condições de contexto além da proximidade geográfica. Um app recebe callbacks sempre que o estado do contexto muda. Por exemplo, se o app definir uma cerca para fones de ouvido, ele vai receber callbacks quando os fones de ouvido forem conectados e desconectados.
É possível usar a API Fence para definir cercas com base em indicadores de contexto, como estes:
- A localização atual do usuário (latitude/longitude)
- A atividade atual do usuário, como caminhar ou dirigir.
- Condições específicas do dispositivo, como se os fones de ouvido estão conectados.
- Proximidade de beacons próximos
A API Fence permite combinar vários
sinais de contexto
para criar cercas com operadores booleanos AND
, OR
e NOT
. O app vai receber callbacks sempre que as condições de cerca forem atendidas. Confira alguns exemplos de
possíveis cercas:
- O usuário conecta os fones de ouvido e começa a caminhar.
- O usuário entra em uma fronteira geográfica de 100 metros antes das 17h em um dia de semana.
- O usuário entra no alcance de um beacon BLE específico.
O exemplo a seguir mostra como definir uma cerca que é ativada sempre que o usuário caminha:
AwarenessFence walkingFence = DetectedActivityFence.during(DetectedActivityFence.WALKING);
Depois de definir uma cerca, faça o seguinte:
- Chame
updateFences
para registrar a cerca e receber callbacks. - Defina um callback que possa ser invocado quando o estado da cerca mudar.
O exemplo a seguir mostra um método que cria e registra uma cerca. Neste
exemplo, uma subclasse personalizada de BroadcastReceiver
é usada para processar a
intent quando a cerca é acionada.
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);
}
}
}