Visão geral da API Fence

Na API Awareness, o conceito de cercas é retirado da fronteira geográfica virtual, 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 da fronteira geográfica virtual. A API Fence amplia o conceito de fronteira geográfica virtual para incluir muitas outras condições contextuais, além da proximidade geográfica. Um app recebe callbacks sempre que o estado do contexto é transferido. Por exemplo, se seu app define uma cerca para fones de ouvido, ele recebe callbacks quando os fones de ouvido estão conectados e quando estão desconectados.

Você pode usar a Fence API para definir limites com base em sinais de contexto, como o seguinte:

  • O local atual do usuário (latitude/longitude)
  • A atividade atual do usuário, como caminhar ou dirigir.
  • Condições específicas do dispositivo, por exemplo, se os fones de ouvido estão conectados.
  • Proximidade de sensores próximos

A API Fence permite combinar vários sinais de contexto para criar limites com os operadores booleanos AND, OR e NOT. Seu app recebe callbacks sempre que as condições de limite são atendidas. Veja alguns exemplos de limites:

  • O usuário conecta fones de ouvido e começa a andar.
  • O usuário insere uma fronteira geográfica virtual de 100 metros antes das 17h em um dia da semana.
  • O usuário insere um intervalo de um beacon BLE específico.

O exemplo a seguir mostra como definir um limite que é ativado sempre que o usuário caminha:

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

Depois de definir um limite, faça o seguinte:

  • Chame updateFences para registrar o limite e receber callbacks.
  • Defina um callback que possa ser invocado quando o estado do limite for alterado.

O exemplo a seguir mostra um método que cria e registra um limite. Neste exemplo, uma subclasse personalizada de BroadcastReceiver é usada para processar a intent quando o limite é acionado.

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