Android Automotive OS की मदद से लोग, कार में ऐप्लिकेशन इंस्टॉल कर सकते हैं. इस तक पहुंचने के लिए इस प्लैटफ़ॉर्म का इस्तेमाल करने वाले लोगों को, ड्राइवर के लिए ऑप्टिमाइज़ किया गया ऐसा ऐप्लिकेशन उपलब्ध कराना होगा जो Android Automotive OS के साथ काम करता है. आप सारे कोड का फिर से इस्तेमाल कर सकते हैं और संसाधन मिल जाते हैं, लेकिन आपको एक अलग बिल्ड बनाना होगा, जो इस पेज पर दी गई ज़रूरी शर्तों को पूरा करता हो.
डेवलपमेंट की खास जानकारी
Android Automotive OS की सुविधा जोड़ने के लिए, सिर्फ़ कुछ चरणों को पूरा करना होगा. इनके बारे में बताया गया है सेक्शन पढ़ें:
- Android Studio में वाहन संबंधित सुविधाएं चालू करें.
- ऑटोमोटिव मॉड्यूल बनाएं.
- Gradle डिपेंडेंसी अपडेट करें.
- विकल्प के तौर पर, सेटिंग और साइन-इन गतिविधियां लागू करें.
- इसके अलावा, मीडिया होस्ट के बारे में सलाह पढ़ें.
डिज़ाइन पर ध्यान देना
Android Automotive OS, इस बात का ध्यान रखता है कि आपके ऐप्लिकेशन की मीडिया ब्राउज़र सेवा से मिलने वाली आय. इसका मतलब है कि आपका ऐप्लिकेशन यूज़र इंटरफ़ेस (यूआई) नहीं बनाता और इनमें से कुछ भी शुरू नहीं करता जब कोई उपयोगकर्ता मीडिया प्लेबैक ट्रिगर करता है, तो आपकी गतिविधियां.
अगर सेटिंग या साइन-इन गतिविधियां लागू की जा रही हैं, तो ये गतिविधियां वाहन के हिसाब से सही होनी चाहिए. डिज़ाइन से जुड़े दिशा-निर्देश देखें इस टूल की मदद से, Android Automotive OS के लिए ऐप्लिकेशन की उन जगहों को डिज़ाइन किया जा सकता है.
अपना प्रोजेक्ट सेट अप करना
चालू करने के लिए, आपको अपने ऐप्लिकेशन के प्रोजेक्ट के कई हिस्से सेट अप करने होंगे Android Automotive OS के लिए
Android Studio में वाहन संबंधित सुविधाएं चालू करें
Android Studio 4.0 या इसके बाद के वर्शन का इस्तेमाल करें, ताकि यह पक्का किया जा सके कि Automotive OS की सभी सुविधाएं चालू किया गया.
वाहन संबंधित मॉड्यूल बनाना
Android Automotive OS के कुछ कॉम्पोनेंट, जैसे कि मेनिफ़ेस्ट में अलग-अलग प्लैटफ़ॉर्म के हिसाब से ज़रूरी शर्तें. एक ऐसा मॉड्यूल बनाएं जो इन कॉम्पोनेंट का कोड, आपके प्रोजेक्ट में मौजूद दूसरे कोड से अलग होता है, जैसे कि आपके फ़ोन ऐप्लिकेशन के लिए इस्तेमाल किया गया.
अपने प्रोजेक्ट में Automotive मॉड्यूल जोड़ने के लिए, यह तरीका अपनाएं:
- Android Studio में, फ़ाइल > नया > नया मॉड्यूल.
- Automotive Module को चुनें. इसके बाद, आगे बढ़ें पर क्लिक करें.
- ऐप्लिकेशन/लाइब्रेरी का नाम डालें. लोगों को यह नाम दिखता है Android Automotive OS पर आपका ऐप्लिकेशन.
- मॉड्यूल का नाम डालें.
- पैकेज के नाम में बदलाव करें, ताकि वह आपके ऐप्लिकेशन के हिसाब से हो.
कम से कम SDK टूल के लिए, एपीआई 28: Android 9.0 (पाई) चुनें. इसके बाद, क्लिक करें आगे बढ़ें पर टैप करें.
Android Automotive OS के साथ काम करने वाली सभी कारें, Android 9 (एपीआई लेवल 28) पर चलती हैं या ज़्यादा है, इसलिए इस मान को चुनने से सभी को टारगेट किया जाता है इन कार के साथ काम करता है.
कोई गतिविधि नहीं को चुनें और फिर पूरा करें पर क्लिक करें.
Android Studio में मॉड्यूल बनाने के बाद, AndroidManifest.xml
को इसमें खोलें
आपका नया ऑटोमोटिव मॉड्यूल:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.media">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme" />
<uses-feature
android:name="android.hardware.type.automotive"
android:required="true" />
</manifest>
application
एलिमेंट में, ऐप्लिकेशन के बारे में कुछ स्टैंडर्ड जानकारी होती है. साथ ही, इसमें uses-feature
एलिमेंट भी होता है, जो Android Automotive OS के साथ काम करने की जानकारी देता है. ध्यान दें कि
मेनिफ़ेस्ट में किसी गतिविधि के बारे में नहीं बताया गया है.
अगर आपने सेटिंग या साइन-इन गतिविधियों को लागू किया है, तो उन्हें यहां जोड़ें. ये गतिविधियां, सिस्टम के ज़रिए साफ़ तौर पर इंटेंट का इस्तेमाल करके ट्रिगर की जाती हैं. साथ ही, ये ऐसी ही गतिविधियां हैं जिनके बारे में Android Automotive OS वाले ऐप्लिकेशन के मेनिफ़ेस्ट में बताया जाता है.
कोई भी सेटिंग या साइन-इन गतिविधियां जोड़ने के बाद, इस तरीके से अपनी मेनिफ़ेस्ट फ़ाइल पूरी करें
application
एलिमेंट में android:appCategory="audio"
एट्रिब्यूट सेट करना
साथ ही, ये uses-feature
एलिमेंट भी जोड़े जा सकते हैं:
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.media"> <application android:allowBackup="true" android:appCategory="audio" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme" /> <uses-feature android:name="android.hardware.type.automotive" android:required="true" /> <uses-feature android:name="android.hardware.wifi" android:required="false" /> <uses-feature android:name="android.hardware.screen.portrait" android:required="false" /> <uses-feature android:name="android.hardware.screen.landscape" android:required="false" /> </manifest>
इन सुविधाओं को साफ़ तौर पर required="false"
पर सेट करने से यह पक्का होता है कि
आपके ऐप्लिकेशन का Automotive OS में उपलब्ध हार्डवेयर की सुविधाओं में कोई समस्या नहीं है
डिवाइस.
Android Automotive OS के लिए, मीडिया सहायता का एलान करें
इस मेनिफ़ेस्ट एंट्री का इस्तेमाल करके, यह बताएं कि आपका ऐप्लिकेशन काम करता है Android Automotive ओएस:
<application>
...
<meta-data android:name="com.android.automotive"
android:resource="@xml/automotive_app_desc"/>
...
</application>
इस मेनिफ़ेस्ट एंट्री का मतलब ऐसी एक्सएमएल फ़ाइल से है जो Automotive के बारे में जानकारी देती है जो आपके ऐप्लिकेशन में काम करते हैं.
यह बताने के लिए कि आपका एक मीडिया ऐप्लिकेशन है,
आपकी res/xml/
डायरेक्ट्री में automotive_app_desc.xml
नाम की एक्सएमएल फ़ाइल
प्रोजेक्ट. इस फ़ाइल में यह कॉन्टेंट शामिल करें:
<automotiveApp>
<uses name="media"/>
</automotiveApp>
इंटेंट फ़िल्टर
Android Automotive OS, आपके मीडिया में गतिविधियां ट्रिगर करने के लिए, अश्लील इंटेंट का इस्तेमाल करता है
है. ऐसी कोई भी गतिविधि शामिल न करें
CATEGORY_LAUNCHER
या ACTION_MAIN
इंटेंट
मेनिफ़ेस्ट फ़ाइल में फ़िल्टर.
नीचे दिए गए उदाहरण में जिस तरह की गतिविधियां हैं, उनमें आम तौर पर किसी फ़ोन या कुछ को टारगेट किया जाता है अन्य मोबाइल डिवाइस. इन गतिविधियों के बारे में मॉड्यूल में बताएं फ़ोन ऐप्लिकेशन बनाता है, न कि उस मॉड्यूल में जो आपके Android Automotive OS को बनाता है है.
<activity android:name=".MyActivity">
<intent-filter>
<!-- You can't use either of these intents for Android Automotive OS -->
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
<!--
In their place, you can include other intent filters for any activities
that your app needs for Android Automotive OS, such as settings or
sign-in activities.
-->
</intent-filter>
</activity>
अपनी Gradle डिपेंडेंसी अपडेट करना
हमारा सुझाव है कि आप अपनी मीडिया ब्राउज़र सेवा को एक अलग मॉड्यूल में रखें. इस मॉड्यूल को अपने फ़ोन ऐप्लिकेशन और वाहन से जुड़े मॉड्यूल के बीच शेयर किया जा सकता है. अगर यह तरीका अपनाया जा रहा है, तो आपको वाहन संबंधित अपडेट करना होगा मॉड्यूल शामिल करने के लिए, जैसा कि नीचे दिए गए स्निपेट में दिखाया गया है:
Groovy
buildscript { ... dependencies { ... implementation project(':shared_module_name') } }
Kotlin
buildscript { ... dependencies { ... implementation(project(":shared_module_name")) } }
सेटिंग और साइन-इन गतिविधियों को लागू करें
मीडिया ब्राउज़र की सेवा के अलावा, वाहन के लिए ऑप्टिमाइज़ किए गए विकल्प भी उपलब्ध कराए जा सकते हैं Android Automotive OS ऐप्लिकेशन की सेटिंग और साइन इन करने की गतिविधियां. इन गतिविधियों से, आपको ऐप्लिकेशन की ऐसी सुविधाएं मुहैया कराने में मदद मिलती है जो इसमें शामिल नहीं हैं Android Media के एपीआई.
इन गतिविधियों को सिर्फ़ तब लागू करें, जब आपके Android Automotive OS ऐप्लिकेशन को उपयोगकर्ताओं को साइन इन करने या ऐप्लिकेशन की सेटिंग तय करने की अनुमति देनी हो. इन गतिविधियों को Android Auto का इस्तेमाल करता है.
गतिविधि से जुड़े वर्कफ़्लो
नीचे दिया गया डायग्राम दिखाता है कि कोई उपयोगकर्ता आपकी सेटिंग और Android Automotive OS का इस्तेमाल करके साइन-इन करने से जुड़ी गतिविधियां:
अपनी सेटिंग और साइन-इन से जुड़ी गतिविधियों में, ध्यान भटकाने वाली गतिविधियों को कम करें
यह पक्का करने के लिए कि आपकी सेटिंग और/या साइन-इन गतिविधियां सिर्फ़ इस्तेमाल के लिए उपलब्ध हों
जब उपयोगकर्ता की कार पार्क की जा रही हो, तब पुष्टि करें कि <activity>
एलिमेंट
नीचे दिया गया <meta-data>
एलिमेंट शामिल न करें. आपका ऐप्लिकेशन अस्वीकार कर दिया जाएगा
समीक्षा के दौरान तब ही सबमिट करें, जब ऐसा कोई एलिमेंट मौजूद हो.
<!-- NOT ALLOWED -->
<meta-data
android:name="distractionOptimized"
android:value="true"/>
कोई सेटिंग गतिविधि जोड़ें
वाहन के लिए ऑप्टिमाइज़ की गई सेटिंग से जुड़ी गतिविधि जोड़ी जा सकती है, ताकि जिसे लोग अपनी कार में, आपके ऐप्लिकेशन के लिए सेटिंग कॉन्फ़िगर कर सकते हैं. आपकी सेटिंग आपकी गतिविधि से अन्य वर्कफ़्लो भी मिल सकते हैं. जैसे, किसी उपयोगकर्ता के खाता या उपयोगकर्ता खाते स्विच करने के लिए किया जा सकता है. याद रखें कि यह गतिविधि सिर्फ़ Android Automotive OS पर चल रहे किसी ऐप्लिकेशन से ट्रिगर हुआ. फ़ोन ऐप्लिकेशन इस डिवाइस से कनेक्ट किए गए हैं Android Auto इसका इस्तेमाल नहीं करता है.
सेटिंग गतिविधि का एलान करना
आपको अपने ऐप्लिकेशन की मेनिफ़ेस्ट फ़ाइल में, सेटिंग गतिविधि के बारे में बताना होगा. इस बारे में यहां दिए गए कोड स्निपेट में बताया गया है:
<application>
...
<activity android:name=".AppSettingsActivity"
android:exported="true"
android:theme="@style/SettingsActivity"
android:label="@string/app_settings_activity_title">
<intent-filter>
<action android:name="android.intent.action.APPLICATION_PREFERENCES"/>
</intent-filter>
</activity>
...
</application>
अपनी सेटिंग गतिविधि लागू करना
जब कोई उपयोगकर्ता आपका ऐप्लिकेशन लॉन्च करता है, तो Android Automotive OS
आपकी ओर से तय की गई सेटिंग की गतिविधि करता है और वह कीमत दिखाता है, जैसे कि एक आइकॉन.
नेविगेट करने के लिए, लोग अपनी कार के डिसप्ले का इस्तेमाल करके, इस किफ़ायती विकल्प पर टैप कर सकते हैं या इसे चुन सकते हैं
उस गतिविधि में शामिल हो सकते हैं. Android Automotive OS, ACTION_APPLICATION_PREFERENCES
भेजता है
इंटेंट, जो आपके ऐप्लिकेशन को आपकी सेटिंग गतिविधि शुरू करने के लिए कहता है.
इस सेक्शन के बाकी हिस्से में, अपने ऐप्लिकेशन के लिए सेटिंग गतिविधि लागू करने के लिए, Universal Android Music Player (UAMP) के सैंपल ऐप्लिकेशन के कोड में बदलाव करने का तरीका बताया गया है.
शुरू करने के लिए, सैंपल कोड डाउनलोड करें:
# Clone the UAMP repositorygit clone https://github.com/android/uamp.git
# Fetch the appropriate pull request to your local repositorygit fetch origin pull/323/head:NEW_LOCAL_BRANCH_NAME
# Switch to the new branchgit checkout NEW_LOCAL_BRANCH_NAME
अपनी गतिविधि लागू करने के लिए, यह तरीका अपनाएं:
automotive/automotive-lib
फ़ोल्डर को अपने Automotive मॉड्यूल में कॉपी करें.- प्रायॉरिटी ट्री को इस तरह परिभाषित करें
automotive/src/main/res/xml/preferences.xml
. कोई ऐसा
PreferenceFragmentCompat
लागू करें जो आपकी सेटिंग गतिविधि में दिखता हो.SettingsFragment.kt
और Uएएमपी मेंSettingsActivity.kt
फ़ाइलें और Android की सेटिंग में गाइड पढ़ें.
सेटिंग गतिविधि को लागू करते समय, इन सबसे सही तरीकों का इस्तेमाल करें प्राथमिकता लाइब्रेरी में मौजूद कुछ कॉम्पोनेंट:
- सेटिंग गतिविधि में मुख्य व्यू के नीचे, दो से ज़्यादा लेवल नहीं होने चाहिए.
DropDownPreference
का इस्तेमाल न करें. इसके बजाय,ListPreference
का इस्तेमाल करें.- संगठन के कॉम्पोनेंट:
PreferenceScreen
- यह आपके प्राथमिकताएं ट्री का टॉप लेवल होना चाहिए.
PreferenceCategory
- इसका इस्तेमाल,
Preference
ऑब्जेक्ट को एक साथ ग्रुप करने के लिए किया जाता है. title
शामिल करें.
- इसका इस्तेमाल,
- नीचे दिए गए सभी कॉम्पोनेंट में
key
औरtitle
शामिल करें. आप यह भी कर सकते हैं एकsummary
, एकicon
या दोनों को शामिल करें:Preference
- अपने
onPreferenceTreeClick()
PreferenceFragmentCompat
लागू करना.
- अपने
CheckBoxPreference
- शर्त के हिसाब से टेक्स्ट के लिए,
summary
के बजायsummaryOn
याsummaryOff
हो सकता है.
- शर्त के हिसाब से टेक्स्ट के लिए,
SwitchPreference
- शर्त वाले टेक्स्ट के लिए,
summary
के बजायsummaryOn
याsummaryOff
का इस्तेमाल किया जा सकता है. - इसमें
switchTextOn
याswitchTextOff
शामिल हो सकता है.
- शर्त वाले टेक्स्ट के लिए,
SeekBarPreference
- एक
min
,max
, औरdefaultValue
शामिल करें.
- एक
EditTextPreference
dialogTitle
,positiveButtonText
, औरnegativeButtonText
शामिल करें.- इसमें
dialogMessage
और/याdialogLayoutResource
शामिल हो सकते हैं.
com.example.android.uamp.automotive.lib.ListPreference
- यह ज़्यादातर
ListPreference
से मिलता है. - इसका इस्तेमाल,
Preference
ऑब्जेक्ट की एक विकल्प वाली सूची दिखाने के लिए किया जाता है. - इसमें
entries
और उससे जुड़ेentryValues
की कोई ऐरे होनी चाहिए.
- यह ज़्यादातर
com.example.android.uamp.automotive.lib.MultiSelectListPreference
- ज़्यादातर
MultiSelectListPreference
से मिलता है - इसका इस्तेमाल,
Preference
ऑब्जेक्ट की कई-विकल्प वाली सूची दिखाने के लिए किया जाता है. - इसमें
entries
का कलेक्शन और उससे जुड़ाentryValues
होना चाहिए.
- ज़्यादातर
साइन-इन गतिविधि जोड़ें
अगर उपयोगकर्ता को आपके ऐप्लिकेशन का इस्तेमाल करने से पहले साइन इन करना ज़रूरी है, तो वाहन के लिए ऑप्टिमाइज़ की गई साइन इन गतिविधि जो आपके ऐप्लिकेशन में साइन इन और उससे साइन आउट करने को हैंडल करता है. आपके पास साइन-इन और साइन-आउट करने का विकल्प भी है वर्कफ़्लो को सेटिंग गतिविधि में सेव करना है, लेकिन अगर आपके ऐप्लिकेशन का इस्तेमाल तब तक नहीं किया जा सकता, जब तक कोई उपयोगकर्ता आपके ऐप्लिकेशन का इस्तेमाल नहीं करता साइन इन करता है. याद रखें कि यह गतिविधि केवल तभी ट्रिगर होती है जब कोई ऐप्लिकेशन Android Automotive OS. Android Auto से कनेक्ट किए गए फ़ोन ऐप्लिकेशन इसका इस्तेमाल नहीं करते.
ऐप्लिकेशन शुरू करने पर साइन इन करना ज़रूरी है
मीडिया ब्राउज़र इस्तेमाल करें, ताकि उपयोगकर्ता को ऐप्लिकेशन इस्तेमाल करने से पहले साइन इन करना पड़े सेवा को ये काम करने होंगे:
- अपनी सेवा की
onLoadChildren()
विधि में, इसका उपयोग करकेnull
परिणाम भेजेंsendResult()
तरीका. - मीडिया सेशन के लिए,
PlaybackStateCompat
को सेट करेंSTATE_ERROR
तकsetState()
का इस्तेमाल करके तरीका. इससे Android Automotive OS को पता चलता है कि अब तक कोई और कार्रवाई नहीं की जा सकती गड़बड़ी को ठीक कर दिया गया है. - मीडिया सेशन के
PlaybackStateCompat
गड़बड़ी कोड कोERROR_CODE_AUTHENTICATION_EXPIRED
पर सेट करें. इससे Android Automotive OS को पता चलता है कि उपयोगकर्ता को पुष्टि करनी होगी. - मीडिया सेशन की
PlaybackStateCompat
सेट करेंsetErrorMessage()
का इस्तेमाल करके गड़बड़ी का मैसेज दिखना तरीका. गड़बड़ी का यह मैसेज लोगों को दिख रहा है. इसलिए, इसे स्थानीय भाषा में लिखें उपयोगकर्ता की मौजूदा स्थान-भाषा के लिए. मीडिया सेशन की
PlaybackStateCompat
सेट करेंsetExtras()
का इस्तेमाल करने वाली दूसरी सुविधाएं तरीका. नीचे दी गई दो कुंजियां शामिल करें:PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_LABEL
: साइन-इन वर्कफ़्लो शुरू करने वाले बटन पर दिखने वाली स्ट्रिंग. यह स्ट्रिंग उपयोगकर्ता को दिखाई जाती है, इसलिए इसका अनुवाद उपयोगकर्ता के मौजूदा स्थान-भाषा.PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_INTENT
: एकPendingIntent
, जो जब उपयोगकर्ताPLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_LABEL
.
नीचे दिए गए कोड स्निपेट में बताया गया है कि आपके ऐप्लिकेशन का इस्तेमाल करने से पहले, उपयोगकर्ता को साइन इन करने की ज़रूरत क्यों पड़ सकती है:
Kotlin
import androidx.media.utils.MediaConstants val signInIntent = Intent(this, SignInActivity::class.java) val signInActivityPendingIntent = PendingIntent.getActivity(this, 0, signInIntent, 0) val extras = Bundle().apply { putString( MediaConstants.PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_LABEL, "Sign in" ) putParcelable( MediaConstants.PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_INTENT, signInActivityPendingIntent ) } val playbackState = PlaybackStateCompat.Builder() .setState(PlaybackStateCompat.STATE_ERROR, 0, 0f) .setErrorMessage( PlaybackStateCompat.ERROR_CODE_AUTHENTICATION_EXPIRED, "Authentication required" ) .setExtras(extras) .build() mediaSession.setPlaybackState(playbackState)
Java
import androidx.media.utils.MediaConstants; Intent signInIntent = new Intent(this, SignInActivity.class); PendingIntent signInActivityPendingIntent = PendingIntent.getActivity(this, 0, signInIntent, 0); Bundle extras = new Bundle(); extras.putString( MediaConstants.PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_LABEL, "Sign in"); extras.putParcelable( MediaConstants.PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_INTENT, signInActivityPendingIntent); PlaybackStateCompat playbackState = new PlaybackStateCompat.Builder() .setState(PlaybackStateCompat.STATE_ERROR, 0, 0f) .setErrorMessage( PlaybackStateCompat.ERROR_CODE_AUTHENTICATION_EXPIRED, "Authentication required" ) .setExtras(extras) .build(); mediaSession.setPlaybackState(playbackState);
उपयोगकर्ता की पुष्टि हो जाने के बाद, PlaybackStateCompat
को STATE_ERROR
के अलावा किसी दूसरी स्थिति पर सेट करें. इसके बाद, ऐक्टिविटी के finish()
मैथड को कॉल करके, उपयोगकर्ता को Android Automotive OS पर वापस ले जाएं.
अपनी साइन-इन गतिविधि लागू करना
Google कई तरह के आइडेंटिटी टूल उपलब्ध कराता है जिसकी मदद से उपयोगकर्ताओं को अपनी कारों में आपके ऐप्लिकेशन में साइन इन करने में मदद मिल सकती है. कुछ सूचनाएं मिल रही हैं Firebase से पुष्टि करने जैसे टूल का इस्तेमाल करके, फ़ुल-स्टैक टूलकिट उपलब्ध कराते हैं. पुष्टि करने के अनुभव को पसंद के मुताबिक बनाने में मदद करता है. अन्य टूल, उपयोगकर्ता के मौजूदा क्रेडेंशियल या अन्य टेक्नोलॉजी का इस्तेमाल करते हैं. इससे, उपयोगकर्ताओं के लिए साइन-इन करने का बेहतर अनुभव देने में मदद मिलती है.
नीचे दिए गए टूल, साइन-इन करने की प्रोसेस को आसान बनाने में आपकी मदद कर सकते हैं उन उपयोगकर्ताओं के लिए अनुभव जो पहले किसी दूसरे डिवाइस पर साइन इन कर चुके हैं:
- एक टैप में साइन इन और साइन-अप: अगर आपने पहले ही One Tap चालू किया हुआ है, तो आपके फ़ोन ऐप्लिकेशन जैसे दूसरे डिवाइसों के लिए, Android Automotive OS ऐप्लिकेशन, जिसकी मदद से मौजूदा One Tap का इस्तेमाल किया जा सकता है.
- Google साइन इन: अगर आपने अपने फ़ोन ऐप्लिकेशन जैसे अन्य डिवाइसों के लिए, Google साइन इन की सुविधा पहले से ही लागू कर दी है, तो Android Automotive OS ऐप्लिकेशन के लिए भी Google साइन इन की सुविधा लागू करें. इससे, Google साइन इन का इस्तेमाल करने वाले मौजूदा उपयोगकर्ताओं को मदद मिलेगी.
- Google की मदद से, जानकारी अपने-आप भरने की सुविधा:अगर उपयोगकर्ताओं ने Google की मदद से, जानकारी अपने-आप भरने की सुविधा चालू की है उसके क्रेडेंशियल, Google Password Manager में सेव हो जाते हैं. जब वे उपयोगकर्ता आपके Android Automotive OS ऐप्लिकेशन में साइन इन करते हैं, तो अपने-आप जानकारी भरने की सुविधा Google, सेव किए गए काम के क्रेडेंशियल का सुझाव देता है. Google की मदद से, जानकारी अपने-आप भरने की सुविधा का इस्तेमाल करने के लिए, ऐप्लिकेशन डेवलप करने की ज़रूरत नहीं होती. हालांकि, ऐप्लिकेशन डेवलपर बेहतर गुणवत्ता वाले परिणामों के लिए अपने ऐप्लिकेशन ऑप्टिमाइज़ कर सकते हैं. Google की मदद से, जानकारी अपने-आप भरने की सुविधा, Android 8.0 वाले सभी डिवाइसों पर काम करती है (एपीआई लेवल 26) या इसके बाद का वर्शन. इसमें Android Automotive OS भी शामिल है.
Account Manager का इस्तेमाल करें
पुष्टि करने वाले Android Automotive OS वाले ऐप्लिकेशन का इस्तेमाल करना ज़रूरी है Account Manager पर इसकी ये वजहें हो सकती हैं:
- बेहतर उपयोगकर्ता अनुभव और खाते को मैनेज करना आसान: उपयोगकर्ता आसानी से सभी सिस्टम सेटिंग में मौजूद खाता मेन्यू से अपने खाते बनाना, जिसमें साइन-इन करना भी शामिल है और साइन-आउट करें.
- "मेहमान" के लिए अनुभव: कारें शेयर किए जाने वाले डिवाइस हैं. इसका मतलब है कि OEM, वाहन में "मेहमान" के लिए अनुभव चालू कर सकते हैं. इस मोड में, खाते नहीं जोड़े जा सकते. यह
DISALLOW_MODIFY_ACCOUNTS
का इस्तेमाल करके, पाबंदी लगाई गई हैAccountManager
के लिए.
अनुमतियां
अगर आपको उपयोगकर्ता से अनुमतियों का अनुरोध करना है, तो उसी फ़्लो का इस्तेमाल करें गतिविधि वर्कफ़्लो में पुष्टि करने से जुड़ी गतिविधि या सेटिंग से जुड़ी गतिविधि डायग्राम को पिछले सेक्शन में दिखाया गया है.
मीडिया होस्ट के संकेत पढ़ें
इससे कनेक्ट होने वाले सिस्टम ऐप्लिकेशन (उसके वर्शन सहित) पर निर्भर करते हुए तो आपकी मीडिया ब्राउज़र सेवा, आपके ऐप्लिकेशन को निम्न अतिरिक्त चीज़ें प्राप्त हो सकती हैं:
गड़बड़ी ठीक करना
Android Automotive OS पर मीडिया ऐप्लिकेशन में होने वाली गड़बड़ियों की जानकारी, मीडिया सेशन के PlaybackStateCompat
के ज़रिए दी जाती है. सभी गड़बड़ियों के लिए, PlaybackStateCompat
में गड़बड़ी का सही कोड और गड़बड़ी का मैसेज सेट करें. इससे Toast
दिखता है
डालें.
जब कोई गड़बड़ी होती है, लेकिन वीडियो चलना जारी रहता है, तो गैर-घातक जारी करें गड़बड़ी ठीक करें. उदाहरण के लिए, उपयोगकर्ता किसी ऐप्लिकेशन में साइन इन करने से पहले उसमें संगीत चला सकता है, लेकिन गाने को स्किप करने से पहले उन्हें साइन इन करना होगा. जब किसी ऐसी गड़बड़ी का इस्तेमाल किया जाता है जो गंभीर नहीं है, तो सिस्टम सुझाव दे सकता है कि उपयोगकर्ता मौजूदा मीडिया आइटम.
कोई साधारण गड़बड़ी जारी करने पर, अपनी बाकी जानकारी को सुरक्षित रखें
गड़बड़ी के कोड और गड़बड़ी के मैसेज के अलावा, PlaybackStateCompat
जैसा है. इसका इस्तेमाल करके
अप्रोच का इस्तेमाल करके, मौजूदा मीडिया आइटम को चलाया जा सकता है, लेकिन उपयोगकर्ता उस दौरान
तय करता है कि साइन इन करना है या नहीं.
जब वीडियो न चलाया जा सके, जैसे कि जब इंटरनेट कनेक्शन न हो और
कोई ऑफ़लाइन सामग्री नहीं, PlaybackStateCompat
स्थिति को STATE_ERROR
पर सेट करें.
अपने PlaybackStateCompat
को अपडेट करने के बाद, गड़बड़ी के सभी कोड और गड़बड़ी के मैसेज मिटाएं. इससे, एक ही गड़बड़ी के लिए कई चेतावनियां दिखने से बचेंगी.
अगर किसी भी समय आप ब्राउज़ ट्री लोड नहीं कर पा रहे हैं—उदाहरण के लिए, अगर
पुष्टि करना ज़रूरी है और उपयोगकर्ता साइन इन नहीं है—कोई खाली जगह भेजें
ब्राउज़ ट्री. इसे दिखाने के लिए, onLoadChildren()
से इसके लिए शून्य नतीजा दें
रूट मीडिया नोड पर क्लिक करें. ऐसा होने पर, सिस्टम फ़ुल-स्क्रीन पर कॉन्टेंट दिखाता है
PlaybackStateCompat
में गड़बड़ी के मैसेज सेट की गड़बड़ी.
कार्रवाई करने लायक गड़बड़ियां
अगर कोई गड़बड़ी कार्रवाई की जा सकती है, तो नीचे दी गई दो अतिरिक्त चीज़ों को
PlaybackStateCompat
:
PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_LABEL
: गड़बड़ी को ठीक करने के लिए, क्लिक किए जाने वाले बटन का लेबल. यह स्ट्रिंग, उपयोगकर्ता को दिखती है. इसलिए, इसे उपयोगकर्ता की मौजूदा स्थानीय भाषा के हिसाब से बनाएं.PLAYBACK_STATE_EXTRAS_KEY_ERROR_RESOLUTION_ACTION_INTENT
:PendingIntent
, जो गड़बड़ी को ठीक करने के लिए बटन को चलाता है. उदाहरण के लिए, साइन इन करने की गतिविधि को लॉन्च करके.
कार्रवाई की जा सकने वाली गड़बड़ियां, Dialog
के तौर पर दिखती हैं. उपयोगकर्ता इन गड़बड़ियों को सिर्फ़ तब ठीक कर सकते हैं, जब
कार को रोका गया.
गड़बड़ी के मामलों की जांच करना
पुष्टि करें कि आपका ऐप्लिकेशन सभी स्थितियों में गड़बड़ियों को अच्छी तरह हैंडल करता है. इनमें ये शामिल हैं:
- आपके प्रॉडक्ट के अलग-अलग टीयर: उदाहरण के लिए, मुफ़्त बनाम प्रीमियम या साइन इन साइन आउट करने की तुलना में अंतर
- डिस्क की अलग-अलग स्थितियां: उदाहरण के लिए, पार्क किया गया बनाम ड्राइविंग
- कनेक्टिविटी की अलग-अलग स्थितियां: उदाहरण के लिए, ऑनलाइन बनाम ऑफ़लाइन
दूसरी ज़रूरी बातें
Android Automotive तैयार करते समय, इन दूसरी बातों को ध्यान में रखें ओएस ऐप्लिकेशन:
ऑफ़लाइन कॉन्टेंट
अगर लागू हो, तो बिना इंटरनेट के वीडियो चलाने की सुविधा लागू करें. Android Automotive वाली कार ओएस की अपनी डेटा कनेक्टिविटी होनी चाहिए, जिसका मतलब है कि डेटा प्लान में, वाहन की लागत या उपयोगकर्ता ने जो पैसे चुकाए हैं उसमें शामिल होता है. हालांकि, मोबाइल के मुकाबले कारों में ज़्यादा वैरिएबल कनेक्टिविटी भी हो सकती है डिवाइस.
जब आप ऑफ़लाइन सहायता पाने के बारे में सोचें, तो इन बातों का ध्यान रखें रणनीति:
- कॉन्टेंट को डाउनलोड करने का सबसे अच्छा समय तब होता है, जब आपका ऐप्लिकेशन इस्तेमाल किया जा रहा हो.
- यह न मानें कि वाई-फ़ाई की सुविधा उपलब्ध है. हो सकता है कि कार कभी भी वाई-फ़ाई की रेंज में न आए या OEM ने मोबाइल नेटवर्क के लिए वाई-फ़ाई बंद कर दिया हो.
- उपयोगकर्ताओं की उम्मीद के मुताबिक कॉन्टेंट को स्मार्ट तरीके से कैश मेमोरी में सेव करना ठीक है, लेकिन हमारी सलाह है कि आप उपयोगकर्ता को आपकी सेटिंग गतिविधि.
- कारों का डिस्क स्टोरेज अलग-अलग होता है. इसलिए, लोगों को इसे मिटाने का तरीका बताएं ऑफ़लाइन सामग्री, जैसे कि आपके विज्ञापन सेटिंग गतिविधि.
वेबव्यू से जुड़ी सहायता
वेबव्यू Android Automotive OS में काम करते हैं, लेकिन सिर्फ़ इनके लिए काम करते हैं सेटिंग और साइन-इन गतिविधियों को ट्रैक करें. वेबव्यू का इस्तेमाल करने वाली गतिविधियों में "बंद करो" या "वापस जाएं" खर्च को वेबव्यू से बाहर रखा जा सकता है.
वेबव्यू के इस्तेमाल के कुछ उदाहरण यहां दिए गए हैं:
- सेटिंग गतिविधि में, निजता नीति, सेवा की शर्तें या कानून से जुड़े अन्य लिंक दिखाना.
- आपकी साइन-इन गतिविधि में वेब पर आधारित फ़्लो.
वेबव्यू का इस्तेमाल करते समय JavaScript.
अपना वेबव्यू सुरक्षित करें
यह पक्का करने के लिए सभी सावधानियां बरतें कि आपका वेबव्यू
का इस्तेमाल करने के लिए प्रोत्साहित भी करते हैं. यहां दिया गया कोड स्निपेट देखें.
में उपयोग किए गए URL पर वेबव्यू को लॉक करने का उदाहरण
loadUrl()
कॉल करें और रीडायरेक्ट रोकें. हमारा सुझाव है कि आप सुरक्षा के उपाय लागू करें
जैसे संभव हो. उदाहरण के लिए, जब वे
कानून से जुड़े लिंक हों.
Kotlin
override fun shouldOverrideUrlLoading(webView: WebView, webResourceRequest: WebResourceRequest): Boolean { val originalUri: Uri = Uri.parse(webView.originalUrl) // Check for allowed URLs if (originalUri.equals(Uri.parse(BLANK_URL)) || originalUri.equals(webResourceRequest.url)) { return false } if (webResourceRequest.isRedirect) { logger.w("Redirect detected, not following") return true } setupWizardWebViewClientListener.onUriBlocked(webResourceRequest.url) logger.w( String.format( "Navigation prevented to %s original is %s", webResourceRequest.url, originalUri)) return true }
Java
@Override public boolean shouldOverrideUrlLoading(WebView webView, WebResourceRequest webResourceRequest) { Uri originalUri = Uri.parse(webView.getOriginalUrl()); // Check for allowed URLs if (originalUri.equals(Uri.parse(BLANK_URL)) || originalUri.equals(webResourceRequest.getUrl())) { return false; } if (webResourceRequest.isRedirect()) { logger.w("Redirect detected, not following"); return true; } setupWizardWebViewClientListener.onUriBlocked(webResourceRequest.getUrl()); logger.w( String.format( "Navigation prevented to %s original is %s", webResourceRequest.getUrl(), originalUri)); return true; }
पैकेज के नाम
Android Automotive OS के लिए, एक अलग Android पैकेज किट (APK) डिस्ट्रिब्यूट करने की वजह से, ये काम किए जा सकते हैं अपने मोबाइल ऐप्लिकेशन में मौजूद पैकेज के नाम का फिर से इस्तेमाल करें या एक नया पैकेज बनाएं नाम. पैकेज के लिए कोई दूसरा नाम इस्तेमाल करने पर, आपके ऐप्लिकेशन के दो अलग-अलग Play Store होते हैं लिस्टिंग. अगर आप अपने मौजूदा पैकेज के नाम का फिर से इस्तेमाल करते हैं, तो आपके ऐप्लिकेशन में पर लिस्ट बना सकते हैं.
यह मुख्य रूप से कारोबार से जुड़ा एक फ़ैसला होता है. उदाहरण के लिए, अगर आपकी कोई टीम मोबाइल ऐप्लिकेशन और Android Automotive पर काम करने वाली एक अलग टीम को OS ऐप्लिकेशन है, तो पैकेज के अलग-अलग नाम और हर एक टीम अपनी Play Store पेज को खुद मैनेज करती है. Search Ads 360 के पुराने और नए वर्शन के दोनों में से किसी भी तरीके का इस्तेमाल करने के लिए, तकनीकी तौर पर ज़्यादा मेहनत करनी पड़ती है.
नीचे दी गई टेबल में, मौजूदा पैकेज नाम और नए पैकेज नाम का उपयोग करके:
सुविधा | पैकेज का एक ही नाम | नए पैकेज का नाम |
---|---|---|
स्टोर पेज | सिंगल | एक से ज़्यादा |
मिरर किया गया इंस्टॉल | हां: सेटअप विज़र्ड के दौरान “ऐप्लिकेशन को तेज़ी से फिर से इंस्टॉल करना” | नहीं |
Play Store पर समीक्षा की प्रक्रिया | समीक्षाओं को ब्लॉक करना: अगर किसी एक APK की समीक्षा नहीं हो पाती है, तो दूसरे APK जिस रिलीज़ में सबमिट किए गए हैं उसे ब्लॉक कर दिया जाता है | किसी व्यक्ति की समीक्षाएं |
आंकड़े, मेट्रिक, और अहम जानकारी | मिला-जुला डेटा: वाहन संबंधित डेटा को फ़िल्टर करने की सुविधा उपलब्ध है. | अलग करें |
इंडेक्स करना और खोज के नतीजों की रैंकिंग | मौजूदा स्थिति से बाहर निकलें | कोई केबिन बैगेज नहीं |
अन्य ऐप्लिकेशन के साथ इंटिग्रेट करना | शायद किसी बदलाव की ज़रूरत नहीं है, क्योंकि मीडिया कोड को दोनों APK के बीच शेयर किया गया है | शायद आपको इससे जुड़ा ऐप्लिकेशन अपडेट करना पड़े. जैसे, Google Assistant की मदद से यूआरआई प्लेबैक के लिए. |
अक्सर पूछे जाने वाले सवाल
इसके बारे में अक्सर पूछे जाने वाले कुछ सवालों के जवाब पाने के लिए, नीचे दिए गए सेक्शन देखें Android Automotive OS.
हार्डवेयर
क्या मेरे ऐप्लिकेशन को माइक्रोफ़ोन का ऐक्सेस मिल सकता है
Android 10 (एपीआई लेवल 29) या इसके बाद के वर्शन को टारगेट करने वाले ऐप्लिकेशन के लिए, ऑडियो इनपुट शेयर करने से जुड़ा दस्तावेज़ देखें. एपीआई लेवल 29 से पहले, ऐसा करना संभव नहीं है.
हमें कार के किन एपीआई का ऐक्सेस मिल सकता है और कैसे?
सिर्फ़ उन एपीआई का इस्तेमाल किया जा सकता है जिन्हें OEM ने बिना अनुमति के सार्वजनिक किया है. प्रक्रियाएं पूरी की जा रही हैं को इन एपीआई को ऐक्सेस करने के तरीके का स्टैंडर्ड तय करने के लिए डेवलप किया गया है.
ऐप्लिकेशन SetProperty()
का इस्तेमाल करके, कार के एपीआई को ऐक्सेस कर सकते हैं
और GetProperty()
CarPropertyManager
में देखें.
सोर्स कोड देखें
या रेफ़रंस दस्तावेज़ का इस्तेमाल करके,
सभी उपलब्ध प्रॉपर्टी की सूची देखें. अगर प्रॉपर्टी के लिए एनोटेट किया गया है
@SystemApi
के साथ, यह पहले से लोड किए गए सिस्टम ऐप्लिकेशन तक सीमित है.
किस तरह के ऑडियो कोडेक इस्तेमाल किए जा सकते हैं?
Android CDD में, ऑडियो कोडेक की जानकारी देखें.
क्या Widevine डीआरएम काम करता है?
हां. वाइडवाइन डीआरएम समर्थित है.
डेवलपमेंट और टेस्टिंग
क्या तीसरे पक्ष के SDK टूल और लाइब्रेरी इस्तेमाल करने के लिए कोई पाबंदी है या कोई सुझाव है?
तीसरे पक्ष के SDK टूल और लाइब्रेरी का इस्तेमाल करने के लिए, हमने कोई खास दिशा-निर्देश नहीं बनाया है. अगर आपने तीसरे पक्ष के SDK टूल और लाइब्रेरी का इस्तेमाल करने का विकल्प चुना है, तब भी इसकी ज़िम्मेदारी आपकी होगी जो कार ऐप्लिकेशन की क्वालिटी से जुड़ी सभी ज़रूरी शर्तों का पालन करता हो.
क्या फ़ोरग्राउंड सेवा का इस्तेमाल किया जा सकता है?
फ़ोरग्राउंड सेवा के लिए, इस्तेमाल का सिर्फ़ यही एक उदाहरण है: ऑफ़लाइन इस्तेमाल के लिए. अगर आपको फ़ोरग्राउंड सेवा के लिए कोई दूसरा इस्तेमाल-उदाहरण चाहिए, जिसके लिए आपको सहायता चाहिए, तो Android Automotive OS के डिस्कशन ग्रुप का इस्तेमाल करके हमसे संपर्क करें.
Android Automotive OS ऐप्लिकेशन पब्लिश करना
Google Play Console का इस्तेमाल करके, Android Automotive OS ऐप्लिकेशन को कैसे पब्लिश करें?
ऐप्लिकेशन पब्लिश करने की प्रोसेस, फ़ोन ऐप्लिकेशन को पब्लिश करने जैसी ही है. हालांकि, डिवाइस का नाप या आकार अलग होता है. Android Automotive इस्तेमाल करने के लिए, अपने ऐप्लिकेशन में ऑप्ट इन करें ओएस का नाप या आकार, यह तरीका अपनाएं:
- Play Console खोलें.
- अपना ऐप्लिकेशन चुनें.
- बाईं ओर मौजूद मेन्यू में, रिलीज़ > सेटअप > बेहतर सेटिंग > डिवाइस का नाप या आकार पर क्लिक करें.
- डिवाइस का नाप या आकार जोड़ें > पर क्लिक करें Android Automotive OS पर जाएं. इसके बाद, Play Console में दिए गए निर्देशों का पालन करें.
अन्य संसाधन
Android Automotive OS के बारे में ज़्यादा जानने के लिए, यहां दी गई अतिरिक्त जानकारी देखें संसाधन.
सैंपल
गाइड
- डिज़ाइन फ़ॉर ड्राइविंग
- मीडिया कंट्रोलर टेस्ट ऐप्लिकेशन का इस्तेमाल करना
- Android Automotive OS पर सूचनाएं
- कार के लिए Android ऐप्लिकेशन की क्वालिटी
ब्लॉग
- डेवलपर के लिए Android Automotive OS से जुड़े अपडेट
- Android Automotive OS के लिए ऐप्लिकेशन डेवलप करना
वीडियो
- कार के लिए मीडिया ऐप्लिकेशन बनाने का तरीका (Android डेवलपर सम्मेलन '19)
- कार के लिए Android ऐप्लिकेशन बनाने का तरीका (Google I/O'19)
Android Automotive OS मीडिया से जुड़ी समस्या की शिकायत करें
अगर Android Automotive के लिए मीडिया ऐप्लिकेशन बनाते समय कोई समस्या आती है तो आप Google समस्या को ट्रैक करने वाला टूल. समस्या वाले टेंप्लेट में मांगी गई पूरी जानकारी भरना न भूलें.
नई समस्या दर्ज करने से पहले, देख लें कि क्या समस्याओं में उसकी शिकायत पहले से की गई है सूची. ट्रैकर में किसी समस्या के लिए स्टार के निशान पर क्लिक करके, उस समस्या के लिए सदस्यता ली जा सकती है और उस पर वोट किया जा सकता है. ज़्यादा जानकारी के लिए, यह देखें किसी समस्या के लिए सदस्यता लेना.