Berkomunikasi di latar belakang

Panduan ini memberikan ringkasan cara mendukung kasus penggunaan utama untuk berkomunikasi dengan perangkat periferal saat aplikasi Anda berjalan di latar belakang:

Ada beberapa opsi untuk mendukung setiap kasus penggunaan tersebut. Masing-masing memiliki kelebihan dan kekurangan yang mungkin membuatnya lebih atau kurang sesuai dengan kebutuhan spesifik Anda.

Diagram berikut menunjukkan tampilan panduan yang disederhanakan di halaman ini:

Temukan perangkat

Pertama, aplikasi Anda perlu menemukan perangkat yang akan dihubungkan. Untuk menemukan perangkat BLE, Anda dapat menggunakan salah satu API berikut:

Di latar belakang

Tidak ada batasan dalam menggunakan salah satu API ini saat aplikasi tidak terlihat, tetapi keduanya membutuhkan proses aplikasi Anda agar aktif. Jika proses aplikasi tidak berjalan, Anda dapat menggunakan solusi berikut:

Hubungkan ke perangkat

Untuk terhubung ke perangkat setelah menemukannya, Anda perlu mendapatkan instance BluetoothDevice untuk perangkat tersebut dari salah satu sumber berikut:

Setelah memiliki instance BluetoothDevice, Anda dapat memulai permintaan koneksi ke perangkat terkait dengan memanggil salah satu metode connectGatt(). Nilai yang Anda teruskan ke boolean autoConnect menentukan manakah dari dua mode koneksi berikut yang digunakan klien GATT:

  • Koneksi langsung (autoconnect = false): Mencoba terhubung ke perangkat periferal secara langsung, dan gagal jika perangkat tidak tersedia. Jika terputus, klien GATT tidak secara otomatis mencoba menghubungkan kembali.
  • Auto connect (autoconnect = true): Mencoba otomatis terhubung ke perangkat periferal jika tersedia. Jika koneksi yang dimulai oleh periferal atau karena periferal berada di luar jangkauan, klien GATT akan otomatis mencoba menghubungkan kembali saat periferal tersedia.

Di latar belakang

Tidak ada batasan untuk menghubungkan ke perangkat saat aplikasi berada di latar belakang, meskipun koneksi akan ditutup jika proses Anda dihentikan. Selain itu, ada batasan pada aktivitas awal (di Android 10 dan yang lebih tinggi) atau layanan latar depan (di Android 12 dan yang lebih tinggi) dari latar belakang.

Dengan demikian, untuk melakukan koneksi saat berada di latar belakang, aplikasi dapat menggunakan solusi berikut:

Tetap terhubung ke perangkat

Idealnya, aplikasi harus mempertahankan koneksi ke perangkat periferal hanya selama diperlukan, dan memutuskan koneksi setelah tugas selesai. Namun, ada dua kasus ketika aplikasi mungkin perlu menjaga koneksi tetap aktif tanpa batas waktu:

Untuk kedua kasus tersebut, opsi berikut tersedia:

Saat beralih antar-aplikasi

Menemukan perangkat, menghubungkannya, dan mentransfer data menghabiskan waktu dan memerlukan banyak resource. Untuk menghindari kehilangan koneksi dan melakukan proses penuh setiap kali pengguna beralih di antara aplikasi atau melakukan tugas bersamaan, Anda harus menjaga koneksi tetap aktif hingga operasi selesai. Anda dapat menggunakan layanan latar depan dengan jenis connectedDevice atau API kehadiran perangkat pendamping.

Selagi mendengarkan notifikasi periferal

Untuk memproses notifikasi periferal, aplikasi harus memanggil setCharacteristicNotification(), memproses callback menggunakan onCharacteristicChanged(), dan menjaga koneksi tetap aktif. Untuk sebagian besar aplikasi, sebaiknya dukung kasus penggunaan ini dengan CompanionDeviceService karena aplikasi mungkin akan terus memproses untuk jangka waktu yang lama. Namun, Anda juga dapat menggunakan layanan latar depan.

Dalam kasus ini, Anda dapat menghubungkan kembali setelah proses dihentikan dengan mengikuti petunjuk di bagian Menghubungkan ke perangkat.