रनटाइम के दौरान जगह की जानकारी ऐक्सेस करने का अनुरोध करें

जब आपके ऐप्लिकेशन की किसी सुविधा को जगह की जानकारी ऐक्सेस करने की ज़रूरत हो, तो अनुमति का अनुरोध करने से पहले, उपयोगकर्ता के उस सुविधा के साथ इंटरैक्ट करने का इंतज़ार करें. इस वर्कफ़्लो में, रनटाइम अनुमतियों का अनुरोध करने के सबसे सही तरीके का पालन किया जाता है. इसके बारे में, ऐप्लिकेशन की अनुमतियों का अनुरोध करने का तरीका बताने वाली गाइड में बताया गया है.

पहली इमेज में, इस प्रोसेस को पूरा करने का तरीका दिखाया गया है. ऐप्लिकेशन में "जगह की जानकारी शेयर करें" सुविधा है. इसके लिए, फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है. हालांकि, जब तक उपयोगकर्ता जगह की जानकारी शेयर करें बटन नहीं चुनता, तब तक ऐप्लिकेशन, जगह की जानकारी की अनुमति का अनुरोध नहीं करता.

उपयोगकर्ता के 'जगह की जानकारी शेयर करें' बटन को चुनने के बाद, सिस्टम की जगह की जानकारी की अनुमति वाला डायलॉग बॉक्स दिखता है
पहली इमेज. जगह की जानकारी शेयर करने की सुविधा के लिए, फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है. अगर उपयोगकर्ता सिर्फ़ ऐप्लिकेशन इस्तेमाल करते समय अनुमति दें चुनता है, तो यह सुविधा चालू हो जाती है.

उपयोगकर्ता, सिर्फ़ आस-पास की जगह की जानकारी ऐक्सेस करने की अनुमति दे सकता है

Android 12 (एपीआई लेवल 31) या उसके बाद वाले वर्शन पर, उपयोगकर्ता अनुरोध कर सकते हैं कि आपका ऐप्लिकेशन, सिर्फ़ आस-पास की जगह की जानकारी को वापस पाए. भले ही, आपका ऐप्लिकेशन, ACCESS_FINE_LOCATION रनटाइम अनुमति का अनुरोध करता हो.

उपयोगकर्ता के इस संभावित व्यवहार को मैनेज करने के लिए, सिर्फ़ ACCESS_FINE_LOCATION अनुमति का अनुरोध न करें. इसके बजाय, रनटाइम के एक ही अनुरोध में, ACCESS_FINE_LOCATION अनुमति और ACCESS_COARSE_LOCATION अनुमति दोनों का अनुरोध करें. अगर सिर्फ़ ACCESS_FINE_LOCATION का अनुरोध किया जाता है, तो Android 12 के कुछ वर्शन पर, सिस्टम इस अनुरोध को अनदेखा कर देता है. अगर आपका ऐप्लिकेशन, Android 12 या उसके बाद वाले वर्शन को टारगेट करता है, तो सिस्टम, यह गड़बड़ी वाला मैसेज Logcat में लॉग करता है:

ACCESS_FINE_LOCATION must be requested with ACCESS_COARSE_LOCATION.

जब आपका ऐप्लिकेशन, ACCESS_FINE_LOCATION और ACCESS_COARSE_LOCATION दोनों का अनुरोध करता है, तो सिस्टम की अनुमतियों वाले डायलॉग में, उपयोगकर्ता के लिए ये विकल्प शामिल होते हैं:

  • सटीक: इससे आपका ऐप्लिकेशन, जगह की सटीक जानकारी पा सकता है.
  • आस-पास: इससे आपका ऐप्लिकेशन, सिर्फ़ आस-पास की जगह की जानकारी पा सकता है.

तीसरी इमेज में दिखाया गया है कि डायलॉग में, दोनों विकल्पों के लिए विज़ुअल क्यू शामिल है, ताकि उपयोगकर्ता को चुनने में मदद मिल सके. उपयोगकर्ता के जगह की सटीक जानकारी चुनने के बाद, वे अनुमति की समयसीमा चुनने के लिए, तीन में से किसी एक बटन पर टैप करते हैं.

Android 12 और उसके बाद वाले वर्शन पर, उपयोगकर्ता सिस्टम सेटिंग में जाकर, किसी भी ऐप्लिकेशन के लिए, अपनी पसंद के मुताबिक जगह की सटीक जानकारी सेट कर सकते हैं. भले ही, उस ऐप्लिकेशन का टारगेट SDK वर्शन कोई भी हो. ऐसा तब भी होता है, जब आपका ऐप्लिकेशन, Android 11 या उससे पहले के वर्शन वाले डिवाइस पर इंस्टॉल हो और फिर उपयोगकर्ता, डिवाइस को Android 12 या उसके बाद वाले वर्शन पर अपग्रेड करे.

डायलॉग में सिर्फ़ अनुमानित जगह की जानकारी दी गई है. इसमें एक के ऊपर एक तीन बटन दिए गए हैं
दूसरी इमेज. सिस्टम की अनुमतियों वाला वह डायलॉग जो तब दिखता है, जब आपका ऐप्लिकेशन सिर्फ़ ACCESS_COARSE_LOCATION का अनुरोध करता है.
डायलॉग में विकल्पों के दो सेट हैं, जो एक-दूसरे के ऊपर हैं
तीसरी इमेज. सिस्टम की अनुमतियों वाला वह डायलॉग जो तब दिखता है, जब आपका ऐप्लिकेशन, रनटाइम के एक ही अनुरोध में, ACCESS_FINE_LOCATION और ACCESS_COARSE_LOCATION दोनों का अनुरोध करता है.

उपयोगकर्ता की पसंद से, अनुमतियों पर असर पड़ता है

यहां दी गई टेबल में, उन अनुमतियों के बारे में बताया गया है जो सिस्टम, आपके ऐप्लिकेशन को देता है. यह इस पर निर्भर करता है कि उपयोगकर्ता, रनटाइम अनुमतियों वाले डायलॉग में कौनसे विकल्प चुनता है:

सटीक आस-पास
ऐप्लिकेशन इस्तेमाल करते समय ACCESS_FINE_LOCATION और
ACCESS_COARSE_LOCATION
ACCESS_COARSE_LOCATION
सिर्फ़ इस बार अनुमति दें ACCESS_FINE_LOCATION और
ACCESS_COARSE_LOCATION
ACCESS_COARSE_LOCATION
अनुमति न दें जगह की जानकारी ऐक्सेस करने की कोई अनुमति नहीं जगह की जानकारी ऐक्सेस करने की कोई अनुमति नहीं

यह जानने के लिए कि सिस्टम ने आपके ऐप्लिकेशन को कौनसी अनुमतियां दी हैं, अनुमतियों के अनुरोध की रिटर्न वैल्यू देखें. आपके पास, यहां दिए गए कोड की तरह कोड में Jetpack लाइब्रेरी इस्तेमाल करने का विकल्प होता है. इसके अलावा, प्लैटफ़ॉर्म लाइब्रेरी का इस्तेमाल भी किया जा सकता है. इसमें, अनुमति के अनुरोध वाले कोड को खुद मैनेज करना होता है.

Kotlin

@RequiresApi(Build.VERSION_CODES.N)
fun requestPermissions() {
    val locationPermissionRequest = registerForActivityResult(
        ActivityResultContracts.RequestMultiplePermissions()
    ) { permissions ->
        when {
            permissions.getOrDefault(Manifest.permission.ACCESS_FINE_LOCATION, false) -> {
                // Precise location access granted.
            }
            permissions.getOrDefault(Manifest.permission.ACCESS_COARSE_LOCATION, false) -> {
                // Only approximate location access granted.
            }
            else -> {
                // No location access granted.
            }
        }
    }

    // Before you perform the actual permission request, check whether your app
    // already has the permissions, and whether your app needs to show a permission
    // rationale dialog. For more details, see Request permissions:
    // https://developer.android.com/training/permissions/requesting#request-permission
    locationPermissionRequest.launch(
        arrayOf(
            Manifest.permission.ACCESS_FINE_LOCATION,
            Manifest.permission.ACCESS_COARSE_LOCATION
        )
    )
}

Java

private void requestPermissions() {

    ActivityResultLauncher<String[]> locationPermissionRequest =
            registerForActivityResult(new ActivityResultContracts
                            .RequestMultiplePermissions(), result -> {

                Boolean fineLocationGranted = null;
                Boolean coarseLocationGranted = null;

                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
                    fineLocationGranted = result.getOrDefault(
                            Manifest.permission.ACCESS_FINE_LOCATION, false);
                    coarseLocationGranted = result.getOrDefault(
                            Manifest.permission.ACCESS_COARSE_LOCATION,false);
                }

                if (fineLocationGranted != null && fineLocationGranted) {
                    // Precise location access granted.
                } else if (coarseLocationGranted != null && coarseLocationGranted) {
                    // Only approximate location access granted.
                } else {
                    // No location access granted.
                }
            }
        );

    // ...

    // Before you perform the actual permission request, check whether your app
    // already has the permissions, and whether your app needs to show a permission
    // rationale dialog. For more details, see Request permissions.
    locationPermissionRequest.launch(new String[] {
            Manifest.permission.ACCESS_FINE_LOCATION,
            Manifest.permission.ACCESS_COARSE_LOCATION
    });
}

जगह की सटीक जानकारी ऐक्सेस करने की अनुमति के लिए अपग्रेड का अनुरोध करना

आपके पास, उपयोगकर्ता से यह अनुरोध करने का विकल्प होता है कि वह आपके ऐप्लिकेशन को, आस-पास की जगह की जानकारी ऐक्सेस करने की अनुमति से अपग्रेड करके, जगह की सटीक जानकारी ऐक्सेस करने की अनुमति दे. हालांकि, उपयोगकर्ता से यह अनुरोध करने से पहले कि वह आपके ऐप्लिकेशन को, जगह की सटीक जानकारी ऐक्सेस करने की अनुमति दे, यह देखें कि आपके ऐप्लिकेशन के इस्तेमाल के मामले में, सटीक जानकारी की ज़रूरत है या नहीं. अगर आपके ऐप्लिकेशन को ब्लूटूथ या वाई-फ़ाई की मदद से, आस-पास मौजूद डिवाइसों के साथ किसी डिवाइस को पेयर करने की ज़रूरत है, तो साथी डिवाइस को पेयर करने की सुविधा या ब्लूटूथ अनुमतियों, अनुमति का अनुरोध करने के बजाय, ACCESS_FINE_LOCATION का इस्तेमाल करें.

उपयोगकर्ता से यह अनुरोध करने के लिए कि वह आपके ऐप्लिकेशन को, आस-पास की जगह की जानकारी ऐक्सेस करने की अनुमति से अपग्रेड करके, जगह की सटीक जानकारी ऐक्सेस करने की अनुमति दे, यह तरीका अपनाएं:

  1. ज़रूरत पड़ने पर, यह बताएं कि आपके ऐप्लिकेशन को इस अनुमति की ज़रूरत क्यों है.
  2. ACCESS_FINE_LOCATION और ACCESS_COARSE_LOCATION अनुमतियों का अनुरोध एक साथ फिर से करें. उपयोगकर्ता ने पहले ही सिस्टम को, आपके ऐप्लिकेशन को आस-पास की जगह की जानकारी ऐक्सेस करने की अनुमति देने की अनुमति दी है. इसलिए, इस बार सिस्टम का डायलॉग अलग होगा. यह चौथी और पांचवी इमेज में दिखाया गया है:
डायलॉग में, &#39;सटीक जगह की जानकारी पर स्विच करें&#39;, &#39;सिर्फ़ इस बार&#39;, और &#39;अस्वीकार करें&#39; विकल्प मौजूद हैं.
चौथी इमेज. उपयोगकर्ता ने पहले आस-पास और ऐप्लिकेशन इस्तेमाल करते समय विकल्प चुने थे. ये विकल्प, तीसरी इमेज में दिखाए गए डायलॉग में मौजूद हैं.
डायलॉग में, &#39;सिर्फ़ इस बार&#39; और &#39;अस्वीकार करें&#39; विकल्प मौजूद हैं.
पांचवी इमेज. उपयोगकर्ता ने पहले आस-पास और सिर्फ़ इस बार अनुमति दें विकल्प चुने थे. ये विकल्प, तीसरी इमेज में दिखाए गए डायलॉग में मौजूद हैं.

शुरुआत में, सिर्फ़ फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति का अनुरोध करना

भले ही, आपके ऐप्लिकेशन की कई सुविधाओं को जगह की जानकारी ऐक्सेस करने की ज़रूरत हो, लेकिन ऐसा हो सकता है कि इनमें से कुछ को ही बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की ज़रूरत हो. इसलिए, हमारा सुझाव है कि आपका ऐप्लिकेशन, जगह की जानकारी की अनुमतियों के लिए बढ़ते हुए अनुरोध करे. इसका मतलब है कि पहले फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति का अनुरोध करे और फिर बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति का अनुरोध करे. बढ़ते हुए अनुरोध करने से, उपयोगकर्ताओं को ज़्यादा कंट्रोल और पारदर्शिता मिलती है. इसकी वजह यह है कि वे बेहतर तरीके से समझ पाते हैं कि आपके ऐप्लिकेशन की किन सुविधाओं को बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की ज़रूरत है.

छठी इमेज में, ऐसे ऐप्लिकेशन का उदाहरण दिखाया गया है जिसे बढ़ते हुए अनुरोधों को मैनेज करने के लिए डिज़ाइन किया गया है. "मौजूदा जगह दिखाएं" और "आस-पास की जगहों के सुझाव दें" दोनों सुविधाओं के लिए, फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है. हालांकि, सिर्फ़ "आस-पास की जगहों के सुझाव दें" सुविधा के लिए, बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है.

फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की सुविधा चालू करने वाला बटन, बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की सुविधा चालू करने वाले बटन से आधी स्क्रीन की दूरी पर मौजूद है
छठी इमेज. दोनों सुविधाओं के लिए, जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है. हालांकि, सिर्फ़ "आस-पास की सुविधाओं के सुझाव दें" सुविधा के लिए, बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है.

बढ़ते हुए अनुरोध करने की प्रोसेस इस तरह होती है:

  1. शुरुआत में, आपके ऐप्लिकेशन को उपयोगकर्ताओं को उन सुविधाओं के बारे में बताना चाहिए जिनके लिए फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है. जैसे, पहली इमेज में "जगह की जानकारी शेयर करें" सुविधा या दूसरी इमेज में "मौजूदा जगह दिखाएं" सुविधा.

    हमारा सुझाव है कि जब तक आपके ऐप्लिकेशन को फ़ोरग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति नहीं मिल जाती, तब तक उन सुविधाओं के लिए उपयोगकर्ता के ऐक्सेस को बंद कर दें जिनके लिए बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति ज़रूरी है.

  2. बाद में, जब उपयोगकर्ता उन सुविधाओं को एक्सप्लोर करते हैं जिनके लिए बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति की ज़रूरत होती है, तब आपके पास बैकग्राउंड में जगह की जानकारी ऐक्सेस करने की अनुमति का अनुरोध करने का विकल्प होता है.

अन्य संसाधन

Android में जगह की जानकारी की अनुमतियों के बारे में ज़्यादा जानने के लिए, यह लेख पढ़ें:

कोडलैब

वीडियो

सैंपल