अपने Android ऐप्लिकेशन (Kotlin/Java) के लिए जियोस्पेशियल एपीआई चालू करना

अपने ऐप्लिकेशन की सेटिंग कॉन्फ़िगर करें, ताकि वह Geospatial API का इस्तेमाल कर सके.

ज़रूरी शर्तें

आगे बढ़ने से पहले, पक्का करें कि आपने बुनियादी एआर (ऑगमेंटेड रिएलिटी) सिद्धांत और ARCore सेशन को कॉन्फ़िगर करने का तरीका समझ लिया है.

ऐप्लिकेशन और कोडलैब का नमूना

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

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

भौगोलिक एपीआई के बारे में ज़्यादा जानकारी के लिए, भौगोलिक डेटा के एपीआई के बारे में जानकारी देखें.

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

पक्का करें कि आपका डेवलपमेंट एनवायरमेंट, ARCore SDK टूल की ज़रूरी शर्तों को पूरा करता हो, जैसा कि क्विकस्टार्ट में बताया गया है.

ARCore API चालू करना

अपने ऐप्लिकेशन में विज़ुअल पोज़िशनिंग सिस्टम (वीपीएस) का इस्तेमाल करने से पहले, आपको Google Cloud के नए या मौजूदा प्रोजेक्ट में ARCore API चालू करना होगा. जियोस्पेशियल ऐंकर को होस्ट करने, सेव करने, और समस्या ठीक करने की ज़िम्मेदारी इस सेवा की है.

कुंजी के बिना पुष्टि करने की सुविधा को प्राथमिकता दी जाती है, लेकिन एपीआई पासकोड से अनुमति देने की सुविधा भी काम करती है.

अपने ऐप्लिकेशन में ज़रूरी लाइब्रेरी जोड़ना

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

अपने ऐप्लिकेशन की build.gradle फ़ाइल में, Play services की जगह की जानकारी वाली लाइब्रेरी को शामिल करने के लिए, Google Play services को सेट अप करें.

dependencies {
  // Apps must declare play-services-location version >= 16.
  // In the following line, substitute `16 (or later)` with the latest version.
  implementation 'com.google.android.gms:play-services-location:16 (or later)'
}

सेशन के कॉन्फ़िगरेशन में जियोस्पेशियल सुविधाएं चालू करें

सेशन बनाने से पहले, अपने सेशन कॉन्फ़िगरेशन में GeospatialMode को ENABLED में बदलें:

Java

Config config = session.getConfig();
config.setGeospatialMode(Config.GeospatialMode.ENABLED);
session.configure(config);

Kotlin

// Enable the Geospatial API.
session.configure(session.config.apply { geospatialMode = Config.GeospatialMode.ENABLED })

जब जियोस्पेशियल मोड ENABLED पर सेट होता है, तब ऐप्लिकेशन को विज़ुअल पोज़िशनिंग सिस्टम (वीपीएस) से जगह की जानकारी लेने की अनुमति होती है.

उपयोगकर्ता को डिवाइस के डेटा के इस्तेमाल की अनुमति देने का अनुरोध करें

ARCore भौगोलिक एपीआई का इस्तेमाल करने वाले ऐप्लिकेशन को उपयोगकर्ता से यह अनुरोध करना चाहिए कि वह यह स्वीकार करे और अपने डिवाइस का डेटा इस्तेमाल करने की अनुमति दे. ज़्यादा जानकारी के लिए, उपयोगकर्ता की निजता से जुड़ी ज़रूरी शर्तें देखें.

देखें कि डिवाइस पर यह सुविधा काम करती है या नहीं

जैसा कि quickstart में बताया गया है, ARCore के साथ काम करने वाले सभी डिवाइस भी Geospatial API के साथ काम करते हैं.

यह देखने के लिए कि उपयोगकर्ता के डिवाइस पर यह काम करता है या नहीं, Session.checkGeospatialModeSupported() पर कॉल करें. अगर यह 'गलत' दिखाता है, तो सेशन को कॉन्फ़िगर करने की कोशिश न करें (नीचे दिया गया है), क्योंकि ऐसा करने पर UnsupportedConfigurationException थ्रो होगा.

रनटाइम के दौरान, उपयोगकर्ता से जगह की जानकारी की अनुमतियां मांगें

आपके ऐप्लिकेशन को रनटाइम के दौरान, जगह की जानकारी की अनुमतियां पाने का अनुरोध करना होगा.

ARCore भौगोलिक एपीआई का इस्तेमाल करने के लिए, आपके ऐप्लिकेशन को नीचे दी गई अतिरिक्त अनुमतियां रजिस्टर करनी होंगी:

  • ACCESS_FINE_LOCATION का इस्तेमाल करें, ताकि उपयोगकर्ता की जगह की सटीक जानकारी का पता लगाया जा सके.

  • ACCESS_COARSE_LOCATION उपयोगकर्ता की जगह की जानकारी सटीक न होने का पता लगाने और उसकी निजता से जुड़ी ज़रूरी शर्तों का पालन करने के लिए. हालांकि, जियोस्पेशियल एपीआई को अनुमानित जगह की जानकारी के साथ काम करने के लिए कॉन्फ़िगर नहीं किया जा सकता. साथ ही, जब उपयोगकर्ता यह अनुमति सेट कर देगा, तब एपीआई अनुरोध पूरे नहीं हो पाएंगे. ज़्यादा जानकारी के लिए नीचे देखें.

  • ACCESS_INTERNET ARCore Geospatial API की सेवा से संपर्क करें.

<manifest ... >
  <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
  <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
  <uses-permission android:name="android.permission.INTERNET" />
</manifest>

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

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

डिवाइस की मौजूदा जगह पर भौगोलिक डेटा की उपलब्धता देखना

भौगोलिक पोज़ तय करने के लिए Geospatial API, VPS और जीपीएस को एक साथ इस्तेमाल करता है, इसलिए एपीआई का इस्तेमाल तब तक किया जा सकता है, जब तक डिवाइस, जगह की जानकारी देने के लिए तैयार है. जिन इलाकों में जीपीएस की सटीक जानकारी नहीं होती है वहां के लिए, यह एपीआई ज़्यादा सटीक पोज़ जनरेट करने के लिए, वीपीएस कवरेज का इस्तेमाल करेगा. जैसे, इनडोर स्पेस और घना शहरी माहौल. सामान्य स्थितियों में, वीपीएस करीब 5 मीटर की स्थिति सटीक और 5 डिग्री घूमने की सटीक जानकारी दे सकता है. Session.checkVpsAvailabilityAsync() का इस्तेमाल करके, पता लगाएं कि दी गई जगह में VPS कवरेज है या नहीं.

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

आगे क्या करना है