जगह की जानकारी का सही तरीके से इस्तेमाल करने पर, आपके ऐप्लिकेशन के उपयोगकर्ताओं को फ़ायदा मिल सकता है. उदाहरण के लिए, अगर आपका ऐप्लिकेशन पैदल चलने या गाड़ी चलाने के दौरान, उपयोगकर्ता को रास्ता ढूंढने में मदद करता है या अगर आपका ऐप्लिकेशन, ऐसेट की जगह की जानकारी ट्रैक करता है, तो उसे नियमित अंतराल पर डिवाइस की जगह की जानकारी पाने की ज़रूरत होती है. भौगोलिक
जगह (अक्षांश और देशांतर) के साथ-साथ, आपके पास उपयोगकर्ता को अन्य
जानकारी देने का विकल्प भी होता है. जैसे, डिवाइस की दिशा (यात्रा की हॉरिज़ॉन्टल दिशा), ऊंचाई या
रफ़्तार. यह जानकारी और अन्य जानकारी, Location
ऑब्जेक्ट में उपलब्ध होती है. इसे आपका ऐप्लिकेशन, कई तरह से जांची गई सही जगह की जानकारी देने वाले एपी101} एपीआई से वापस पा सकता है. इसके जवाब में, एपीआई आपके ऐप्लिकेशन को समय-समय पर,
उपलब्ध सबसे सटीक जगह की जानकारी देता है. यह जानकारी, वाई-फ़ाई और जीपीएस (ग्लोबल पोज़िशनिंग सिस्टम) जैसे, फ़िलहाल उपलब्ध जगह की जानकारी
देने वाले एपीआई पर आधारित होती है. जगह की जानकारी की सटीक जानकारी, एपीआई, आपके अनुरोध की गई जगह की जानकारी की अनुमतियों, और जगह की जानकारी के अनुरोध में सेट किए गए विकल्पों के हिसाब से तय की जाती है.
इस सबक में, आपको कई तरह से जांची गई सही जगह की जानकारी देने वाले एपीआई में मौजूद requestLocationUpdates()
तरीके का इस्तेमाल करके, डिवाइस की जगह की जानकारी के नियमित अपडेट का अनुरोध करने का तरीका बताया गया है.
डिवाइस की वह आखिरी जगह पाना जिसके बारे में जानकारी है
डिवाइस की वह आखिरी जगह जिसके बारे में जानकारी है, एक काम का बेस उपलब्ध कराती है जिससे
शुरू किया जा सके. इससे यह पक्का होता है कि समय-समय पर जगह की जानकारी के अपडेट शुरू करने से पहले, ऐप्लिकेशन के पास जगह की जानकारी मौजूद हो. डिवाइस की वह आखिरी जगह पाने का तरीका बताने वाले सबक में,
डिवाइस की वह आखिरी जगह पाने का तरीका बताया गया है कि
`getLastLocation()` को कॉल करके, डिवाइस की वह आखिरी जगह कैसे पाएं.getLastLocation()
यहां दिए गए सेक्शन में मौजूद स्निपेट में यह माना गया है कि आपके ऐप्लिकेशन ने, डिवाइस की वह आखिरी जगह पहले ही वापस पा ली है और उसे ग्लोबल वैरिएबल
mCurrentLocation में Location ऑब्जेक्ट के तौर पर सेव कर लिया है.
जगह की जानकारी का अनुरोध करना
जगह की जानकारी के अपडेट का अनुरोध करने से पहले, आपके ऐप्लिकेशन को जगह की जानकारी की सेवाओं से कनेक्ट होना चाहिए और जगह की जानकारी का अनुरोध करना चाहिए. जगह की जानकारी की सेटिंग बदलने का तरीका बताने वाले सबक में, यह करने का तरीका बताया गया है. जगह की जानकारी का अनुरोध करने के बाद,
requestLocationUpdates() को कॉल करके, नियमित अपडेट शुरू किए जा सकते हैं.
अनुरोध के फ़ॉर्म के आधार पर, कई तरह से जांची गई सही जगह की जानकारी देने वाला एपीआई, या तो
LocationCallback.onLocationResult()
कॉलबैक तरीके को लागू करता है और उसे Location ऑब्जेक्ट की सूची पास करता है या
PendingIntent
जारी करता है. इसमें, जगह की जानकारी, एक्सटेंड किए गए डेटा में शामिल होती है. अपडेट की सटीक जानकारी और फ़्रीक्वेंसी पर, आपके अनुरोध की गई जगह की जानकारी की अनुमतियों और जगह की जानकारी के अनुरोध वाले ऑब्जेक्ट में सेट किए गए विकल्पों का असर पड़ता है.
इस सबक में,
LocationCallback
कॉलबैक के तरीके का इस्तेमाल करके, अपडेट पाने का तरीका बताया गया है. LocationRequest ऑब्जेक्ट के अपने इंस्टेंस और LocationCallback को पास करके, requestLocationUpdates() को कॉल करें.
यहां दिए गए कोड के सैंपल में दिखाए गए तरीके से, startLocationUpdates() तरीका तय करें:
Kotlin
override fun onResume() { super.onResume() if (requestingLocationUpdates) startLocationUpdates() } private fun startLocationUpdates() { fusedLocationClient.requestLocationUpdates(locationRequest, locationCallback, Looper.getMainLooper()) }
Java
@Override protected void onResume() { super.onResume(); if (requestingLocationUpdates) { startLocationUpdates(); } } private void startLocationUpdates() { fusedLocationClient.requestLocationUpdates(locationRequest, locationCallback, Looper.getMainLooper()); }
ध्यान दें कि ऊपर दिए गए कोड स्निपेट में, बूलियन फ़्लैग
requestingLocationUpdates का रेफ़रंस दिया गया है. इसका इस्तेमाल, यह ट्रैक करने के लिए किया जाता है कि उपयोगकर्ता ने जगह की जानकारी के
अपडेट चालू किए हैं या बंद. अगर उपयोगकर्ताओं ने जगह की जानकारी के अपडेट बंद किए हैं, तो आप उन्हें अपने ऐप्लिकेशन की जगह की जानकारी की ज़रूरत के बारे में बता
सकते हैं. गतिविधि के अलग-अलग इंस्टेंस में, बूलियन फ़्लैग की वैल्यू बनाए रखने के बारे में ज़्यादा जानने के लिए, गतिविधि की स्थिति सेव करना लेख पढ़ें.
जगह की जानकारी के अपडेट का कॉलबैक तय करना
कई तरह से जांची गई सही जगह की जानकारी देने वाला एपीआई,
LocationCallback.onLocationResult()
कॉलबैक तरीके को लागू करता है. इनकमिंग आर्ग्युमेंट में, Location
ऑब्जेक्ट की सूची शामिल होती है. इसमें, जगह की जानकारी का अक्षांश और देशांतर शामिल होता है. यहां दिए गए स्निपेट में,
LocationCallback
इंटरफ़ेस को लागू करने और तरीका तय करने का तरीका बताया गया है. इसके बाद, जगह की जानकारी के अपडेट का टाइमस्टैंप पाने
और अपने ऐप्लिकेशन के यूज़र
इंटरफ़ेस पर अक्षांश, देशांतर, और टाइमस्टैंप दिखाने का तरीका बताया गया है:
Kotlin
private lateinit var locationCallback: LocationCallback // ... override fun onCreate(savedInstanceState: Bundle?) { // ... locationCallback = object : LocationCallback() { override fun onLocationResult(locationResult: LocationResult?) { locationResult ?: return for (location in locationResult.locations){ // Update UI with location data // ... } } } }
Java
private LocationCallback locationCallback; // ... @Override protected void onCreate(Bundle savedInstanceState) { // ... locationCallback = new LocationCallback() { @Override public void onLocationResult(LocationResult locationResult) { if (locationResult == null) { return; } for (Location location : locationResult.getLocations()) { // Update UI with location data // ... } } }; }
जगह की जानकारी के अपडेट रोकना
यह तय करें कि गतिविधि फ़ोकस में न होने पर, जगह की जानकारी के अपडेट रोकने हैं या नहीं. जैसे, जब उपयोगकर्ता किसी दूसरे ऐप्लिकेशन पर स्विच करता है या उसी ऐप्लिकेशन में किसी दूसरी गतिविधि पर स्विच करता है. इससे बैटरी की खपत कम करने में मदद मिल सकती है. हालांकि, यह तब काम का है, जब ऐप्लिकेशन को बैकग्राउंड में चलने के दौरान भी जानकारी इकट्ठा करने की ज़रूरत न हो. इस सेक्शन में, गतिविधि के
onPause() तरीके में अपडेट रोकने का तरीका बताया गया है.
जगह की जानकारी के अपडेट रोकने के लिए, removeLocationUpdates() को कॉल करें. इसमें,
LocationCallback पास करें. इसके लिए, यहां दिया गया कोड का सैंपल देखें:
Kotlin
override fun onPause() { super.onPause() stopLocationUpdates() } private fun stopLocationUpdates() { fusedLocationClient.removeLocationUpdates(locationCallback) }
Java
@Override protected void onPause() { super.onPause(); stopLocationUpdates(); } private void stopLocationUpdates() { fusedLocationClient.removeLocationUpdates(locationCallback); }
यह ट्रैक करने के लिए कि फ़िलहाल जगह की जानकारी के अपडेट चालू हैं या नहीं, बूलियन requestingLocationUpdates
का इस्तेमाल करें. गतिविधि के
onResume() तरीके में, यह देखें
कि फ़िलहाल जगह की जानकारी के अपडेट चालू हैं या नहीं. अगर नहीं हैं, तो उन्हें चालू करें:
Kotlin
override fun onResume() { super.onResume() if (requestingLocationUpdates) startLocationUpdates() }
Java
@Override protected void onResume() { super.onResume(); if (requestingLocationUpdates) { startLocationUpdates(); } }
गतिविधि की स्थिति सेव करना
डिवाइस के कॉन्फ़िगरेशन में बदलाव करने पर, मौजूदा गतिविधि बंद हो सकती है. जैसे, स्क्रीन
ओरिएंटेशन या भाषा में बदलाव करने पर. इसलिए, आपके
ऐप्लिकेशन को वह सारी जानकारी सेव करनी होगी जिसकी ज़रूरत, गतिविधि को फिर से बनाने के लिए होती है.
ऐसा करने का एक तरीका, इंस्टेंस की स्थिति का इस्तेमाल करना है जिसे
Bundle ऑब्जेक्ट में सेव किया गया है.
यहां दिए गए कोड के सैंपल में, इंस्टेंस की स्थिति सेव करने के लिए, गतिविधि के
onSaveInstanceState()
कॉलबैक का इस्तेमाल करने का तरीका बताया गया है:
Kotlin
override fun onSaveInstanceState(outState: Bundle?) { outState?.putBoolean(REQUESTING_LOCATION_UPDATES_KEY, requestingLocationUpdates) super.onSaveInstanceState(outState) }
Java
@Override protected void onSaveInstanceState(Bundle outState) { outState.putBoolean(REQUESTING_LOCATION_UPDATES_KEY, requestingLocationUpdates); // ... super.onSaveInstanceState(outState); }
सेव की गई वैल्यू को गतिविधि के पिछले इंस्टेंस से वापस पाने के लिए, updateValuesFromBundle() तरीका तय करें. हालांकि, ऐसा तब ही किया जा सकता है, जब ये वैल्यू उपलब्ध हों. गतिविधि के
onCreate() तरीके से, इस तरीके को कॉल करें. इसके लिए, यहां दिया गया कोड का सैंपल देखें:
Kotlin
override fun onCreate(savedInstanceState: Bundle?) { // ... updateValuesFromBundle(savedInstanceState) } private fun updateValuesFromBundle(savedInstanceState: Bundle?) { savedInstanceState ?: return // Update the value of requestingLocationUpdates from the Bundle. if (savedInstanceState.keySet().contains(REQUESTING_LOCATION_UPDATES_KEY)) { requestingLocationUpdates = savedInstanceState.getBoolean( REQUESTING_LOCATION_UPDATES_KEY) } // ... // Update UI to match restored state updateUI() }
Java
@Override public void onCreate(Bundle savedInstanceState) { // ... updateValuesFromBundle(savedInstanceState); } private void updateValuesFromBundle(Bundle savedInstanceState) { if (savedInstanceState == null) { return; } // Update the value of requestingLocationUpdates from the Bundle. if (savedInstanceState.keySet().contains(REQUESTING_LOCATION_UPDATES_KEY)) { requestingLocationUpdates = savedInstanceState.getBoolean( REQUESTING_LOCATION_UPDATES_KEY); } // ... // Update UI to match restored state updateUI(); }
इंस्टेंस की स्थिति सेव करने के बारे में ज़्यादा जानने के लिए, Android Activity क्लास का रेफ़रंस देखें.
ध्यान दें: ज़्यादा समय तक डेटा सेव करने के लिए, उपयोगकर्ता की प्राथमिकताओं को अपने ऐप्लिकेशन के
SharedPreferences में सेव किया जा सकता है. अपनी गतिविधि के onPause() तरीके में, शेयर की गई प्राथमिकता सेट करें. साथ ही, onResume() में प्राथमिकता वापस पाएं.
प्राथमिकताएं सेव करने के बारे में ज़्यादा जानने के लिए, की-वैल्यू सेट सेव करना
लेख पढ़ें.
अन्य संसाधन
ज़्यादा जानने के लिए, यहां दिए गए संसाधन देखें: