Praktik terbaik penggunaan lokasi latar belakang

Halaman ini menjelaskan praktik terbaik untuk meminta dan mengelola izin penggunaan lokasi latar belakang.

Meminta izin akses lokasi "Selalu izinkan"

Mulai Android 14, aplikasi harus memiliki izin ACCESS_BACKGROUND_LOCATION untuk mengakses lokasi pengguna. Navigation SDK menyertakan izin ini dalam file manifesnya, sehingga Anda tidak perlu memintanya secara eksplisit (jika tidak diperlukan untuk tujuan lain), karena penggabung manifes Gradle akan memastikannya digabungkan dengan manifes aplikasi.

Namun, memiliki izin ACCESS_BACKGROUND_LOCATION saja tidak cukup untuk mengakses lokasi di latar belakang dan sebaiknya Anda meminta izin lokasi "Izinkan sepanjang waktu" dari pengguna. Hal ini memastikan bahwa aplikasi dapat berjalan di latar belakang dan menampilkan notifikasi, yang memaksimalkan akurasi lokasi selama navigasi.

Perintah harus menjelaskan kepada pengguna bagaimana pemberian izin akan meningkatkan akurasi lokasi dan meningkatkan pengalaman navigasi mereka saat aplikasi berjalan di latar belakang.

dialog izin
contoh

Untuk informasi selengkapnya tentang meminta akses lokasi kepada pengguna, lihat Meminta izin akses lokasi | Sensor dan lokasi | Android Developers dalam dokumentasi developer Android.

Memastikan pembersihan notifikasi navigasi yang tepat

Untuk memastikan aplikasi Anda tidak terus menampilkan notifikasi setelah tidak lagi diperlukan, pastikan Anda melakukan langkah-langkah pembersihan berikut:

  • Setelah memanggil startGuidance(), pastikan untuk memanggil stopGuidance() atau clearDestination().
  • Setelah mendaftarkan ArrivalListener, pastikan untuk membatalkan pendaftarannya.
  • Setelah mendaftarkan RoadSnappedLocationProvider, pastikan untuk membatalkan pendaftarannya.

Menyelesaikan langkah-langkah ini memastikan bahwa notifikasi tidak tetap aktif saat tidak lagi diperlukan, yang dapat menyebabkan baterai cepat habis dan kemungkinan kebocoran memori.

Saat memanggil ulang metode NavigationApi#initForegroundServiceManager, panggil NavigationApi#clearForegroundServiceManager terlebih dahulu

Jika aplikasi Anda menggunakan ForegroundServiceManager, panggil NavigationApi#clearForegroundServiceManager sebelum memanggil NavigationApi#initForegroundServiceManagerProvider, dan jika Anda telah melakukan inisialisasi ForegroundServiceManager, panggil NavigationApi#initForegroundServiceManagerMessageAndIntent. Anda dapat melakukannya untuk memperbarui ID notifikasi atau konten notifikasi setelah melakukan inisialisasi pengelola layanan latar depan.

Tentang batasan baru yang diperkenalkan di Android 14

Android 14 (Android U) memperkenalkan batasan baru pada aplikasi yang mengakses lokasi pengguna di latar belakang. Untuk membantu memitigasi perubahan ini, Navigation SDK diupdate ke versi 5.4.0 untuk mengelola akses lokasi latar belakang dengan lebih baik. Sebaiknya perbarui juga penerapan Anda untuk memastikan aplikasi Anda terus memiliki akses ke data lokasi yang paling akurat.

Pengaruh perubahan di Android 14 terhadap Navigation SDK

Saat Anda memanggil startGuidance() di aplikasi, layanan latar depan akan mulai menampilkan notifikasi pengguna untuk navigasi belokan demi belokan. Navigasi belokan demi belokan bergantung pada kemampuan untuk mengakses lokasi pengguna guna memperbarui rute dan menampilkan panduan visual dan audio yang benar. Mulai Android 14, mengakses lokasi tepat pengguna di latar belakang memerlukan izin dari pengguna. Secara default, jika aplikasi tidak memiliki izin pengguna untuk akses lokasi latar belakang dan mencoba memulai layanan latar depan untuk pembaruan lokasi, sistem akan menampilkan SecurityException, yang menyebabkan aplikasi error.

Cara Navigation SDK mengurangi masalah ini

Mulai versi 5.4.0, Navigation SDK menangani SecurityException ini tanpa memengaruhi aplikasi, sehingga navigasi dapat terus berjalan di latar belakang. Selain itu, Navigation SDK menyertakan izin ACCESS_BACKGROUND_LOCATION dalam AndroidManifest-nya. Dengan cara ini, aplikasi Anda tidak perlu mendeklarasikan izin itu sendiri, karena penggabungan Gradle akan menanganinya. Namun, jika notifikasi tidak ditampilkan kepada pengguna sebelum aplikasi beralih ke latar belakang, Navigation SDK akan mengandalkan sistem untuk memberikan update lokasi. Update sistem ini mungkin tidak sering atau akurat dan menghasilkan pengalaman navigasi yang kurang optimal. Oleh karena itu, sebaiknya Anda juga meminta izin akses lokasi latar belakang kepada pengguna.

Yang dapat dilakukan developer aplikasi untuk meningkatkan akurasi lokasi navigasi

Anda dapat meningkatkan akurasi sinyal lokasi yang digunakan oleh Navigation SDK dengan mengupdate aplikasi untuk meminta pengguna memberikan akses lokasi latar belakang. Untuk mengetahui informasi selengkapnya, lihat Meminta izin akses lokasi "Selalu izinkan".