ภาพรวมของ Fence API

ใน Awareness API แนวคิดรั้วมาจากการกำหนดเขตพื้นที่เสมือน ซึ่งมีการกําหนดภูมิภาคทางภูมิศาสตร์หรือเขตพื้นที่เสมือน และแอปจะได้รับการเรียกกลับเมื่อผู้ใช้เข้าหรือออกจากภูมิภาคเขตพื้นที่เสมือน Fence API ขยายแนวคิดของการกำหนดเขตพื้นที่เสมือนให้รวมเงื่อนไขอื่นๆ อีกมากมายนอกเหนือจากความใกล้ชิดทางภูมิศาสตร์ แอปจะได้รับการเรียกกลับทุกครั้งที่บริบทมีการเปลี่ยนแปลงสถานะ ตัวอย่างเช่น หากแอปกำหนดรั้วสำหรับหูฟัง แอปจะได้รับการเรียกกลับเมื่อเสียบปลั๊กหูฟังและเมื่อถอดปลั๊ก

คุณสามารถใช้ Fence API เพื่อกําหนดรั้วตามสัญญาณบริบท เช่น ต่อไปนี้

  • ตำแหน่งปัจจุบันของผู้ใช้ (ละติจูด/ลองจิจูด)
  • กิจกรรมปัจจุบันของผู้ใช้ เช่น การเดินหรือการขับรถ
  • เงื่อนไขเฉพาะอุปกรณ์ เช่น มีการเสียบปลั๊กหูฟังหรือไม่
  • ระยะทางจากบีคอนที่อยู่ใกล้เคียง

Fence API ช่วยให้คุณรวมสัญญาณบริบทหลายรายการเข้าด้วยกันเพื่อสร้างรั้วด้วยโอเปอเรเตอร์บูลีน AND, OR และ NOT จากนั้นแอปของคุณจะได้รับการเรียกกลับทุกครั้งที่เป็นไปตามเงื่อนไขของรั้ว ตัวอย่างรั้วที่เป็นไปได้มีดังนี้

  • ผู้ใช้เสียบหูฟังและเริ่มเดิน
  • ผู้ใช้เข้าไปในเขตพื้นที่เสมือน 100 เมตรก่อนเวลา 17:00 น. ในวันธรรมดา
  • ผู้ใช้เข้าสู่ระยะสัญญาณของบีคอน BLE ที่เฉพาะเจาะจง

ตัวอย่างต่อไปนี้แสดงวิธีกำหนดรั้วที่จะเปิดใช้งานทุกครั้งที่ผู้ใช้เดิน

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

เมื่อกำหนดรั้วแล้ว คุณต้องดำเนินการต่อไปนี้

  • โทรหา updateFences เพื่อลงทะเบียนรั้วเพื่อรับการติดต่อกลับ
  • กำหนดการเรียกกลับที่เรียกใช้ได้เมื่อสถานะรั้วไฟฟ้ามีการเปลี่ยนแปลง

ตัวอย่างต่อไปนี้แสดงเมธอดที่สร้างและลงทะเบียนรั้ว ในตัวอย่างนี้ มีการใช้คลาสย่อยที่กำหนดเองของ BroadcastReceiver เพื่อจัดการ Intent เมื่อรั้วทริกเกอร์

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