Android Automotive OS ব্যবহারকারীদের গাড়িতে অ্যাপ ইনস্টল করতে দেয়। এই প্ল্যাটফর্মে ব্যবহারকারীদের কাছে পৌঁছানোর জন্য, আপনাকে একটি ড্রাইভার-অপ্টিমাইজ করা অ্যাপ বিতরণ করতে হবে যা Android Automotive OS-এর সাথে সামঞ্জস্যপূর্ণ। আপনি আপনার অ্যান্ড্রয়েড অটো অ্যাপের প্রায় সমস্ত কোড এবং সংস্থানগুলি পুনঃব্যবহার করতে পারেন, তবে আপনাকে অবশ্যই একটি পৃথক বিল্ড তৈরি করতে হবে যা এই পৃষ্ঠার প্রয়োজনীয়তাগুলি পূরণ করে৷
উন্নয়ন ওভারভিউ
অ্যান্ড্রয়েড অটোমোটিভ ওএস সমর্থন যোগ করার জন্য শুধুমাত্র কয়েকটি ধাপের প্রয়োজন, যা অনুসরণ করা বিভাগগুলিতে বর্ণিত হয়েছে:
- অ্যান্ড্রয়েড স্টুডিওতে স্বয়ংচালিত বৈশিষ্ট্যগুলি সক্ষম করুন ৷
- একটি স্বয়ংচালিত মডিউল তৈরি করুন ।
- আপনার Gradle নির্ভরতা আপডেট করুন ।
- ঐচ্ছিকভাবে, সেটিংস এবং সাইন-ইন কার্যক্রম বাস্তবায়ন করুন ।
- ঐচ্ছিকভাবে, মিডিয়া হোস্টের ইঙ্গিতগুলি পড়ুন ।
নকশা বিবেচনা
অ্যান্ড্রয়েড অটোমোটিভ ওএস আপনার অ্যাপের মিডিয়া ব্রাউজার পরিষেবা থেকে প্রাপ্ত মিডিয়া সামগ্রীগুলিকে সাজানোর যত্ন নেয়৷ এর মানে হল যে আপনার অ্যাপটি UI আঁকে না এবং যখন কোনো ব্যবহারকারী মিডিয়া প্লেব্যাক ট্রিগার করে তখন আপনার কোনো কার্যক্রম শুরু করে না।
আপনি সেটিংস বা সাইন-ইন কার্যক্রম বাস্তবায়ন করলে, এই ক্রিয়াকলাপগুলিকে অবশ্যই যানবাহন-অপ্টিমাইজ করা উচিত। আপনার অ্যাপের সেই ক্ষেত্রগুলি ডিজাইন করার সময় Android Automotive OS-এর ডিজাইন নির্দেশিকা পড়ুন।
আপনার প্রকল্প সেট আপ করুন
Android Automotive OS এর জন্য সমর্থন সক্ষম করতে আপনাকে আপনার অ্যাপের প্রকল্পের বেশ কয়েকটি অংশ সেট আপ করতে হবে।
অ্যান্ড্রয়েড স্টুডিওতে স্বয়ংচালিত বৈশিষ্ট্যগুলি সক্ষম করুন
সমস্ত স্বয়ংচালিত ওএস বৈশিষ্ট্যগুলি সক্ষম রয়েছে তা নিশ্চিত করতে Android স্টুডিও 4.0 বা উচ্চতর ব্যবহার করুন৷
একটি স্বয়ংচালিত মডিউল তৈরি করুন
অ্যান্ড্রয়েড অটোমোটিভ ওএসের কিছু উপাদান, যেমন ম্যানিফেস্ট, প্ল্যাটফর্ম-নির্দিষ্ট প্রয়োজনীয়তা রয়েছে। একটি মডিউল তৈরি করুন যা এই উপাদানগুলির কোডকে আপনার প্রকল্পের অন্যান্য কোড থেকে আলাদা রাখতে পারে, যেমন আপনার ফোন অ্যাপের জন্য ব্যবহৃত কোড।
আপনার প্রকল্পে একটি স্বয়ংচালিত মডিউল যোগ করতে এই পদক্ষেপগুলি অনুসরণ করুন:
- অ্যান্ড্রয়েড স্টুডিওতে, ফাইল > নতুন > নতুন মডিউল ক্লিক করুন।
- অটোমোটিভ মডিউল নির্বাচন করুন, তারপর পরবর্তী ক্লিক করুন।
- একটি অ্যাপ্লিকেশন/লাইব্রেরির নাম লিখুন। এই নামটি ব্যবহারকারীরা Android Automotive OS-এ আপনার অ্যাপের জন্য দেখতে পান।
- একটি মডিউল নাম লিখুন।
- আপনার অ্যাপের সাথে মিল রাখতে প্যাকেজের নাম সামঞ্জস্য করুন।
ন্যূনতম SDK-এর জন্য API 28: Android 9.0 (Pie) নির্বাচন করুন এবং তারপর Next এ ক্লিক করুন।
Android Automotive OS সমর্থন করে এমন সমস্ত গাড়ি Android 9 (API লেভেল 28) বা উচ্চতর সংস্করণে চলে, তাই এই মানটি নির্বাচন করা সমস্ত সামঞ্জস্যপূর্ণ গাড়িকে লক্ষ্য করে।
কোন কার্যকলাপ নির্বাচন করুন, এবং তারপর সমাপ্ত ক্লিক করুন.
অ্যান্ড্রয়েড স্টুডিওতে আপনার মডিউল তৈরি করার পরে, আপনার নতুন অটোমোটিভ মডিউলে 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"
এ সেট করা নিশ্চিত করে যে আপনার অ্যাপটি স্বয়ংচালিত ওএস ডিভাইসে উপলব্ধ হার্ডওয়্যার বৈশিষ্ট্যগুলির সাথে বিরোধ করছে না।
Android Automotive OS এর জন্য মিডিয়া সমর্থন ঘোষণা করুন
আপনার অ্যাপ Android Automotive OS সমর্থন করে তা ঘোষণা করতে নিম্নলিখিত ম্যানিফেস্ট এন্ট্রি ব্যবহার করুন:
<application>
...
<meta-data android:name="com.android.automotive"
android:resource="@xml/automotive_app_desc"/>
...
</application>
এই ম্যানিফেস্ট এন্ট্রিটি একটি XML ফাইলকে নির্দেশ করে যা আপনার অ্যাপ সমর্থন করে এমন স্বয়ংচালিত ক্ষমতাগুলি ঘোষণা করে৷
আপনার কাছে একটি মিডিয়া অ্যাপ আছে তা নির্দেশ করতে, আপনার প্রকল্পের res/xml/
ডিরেক্টরিতে automotive_app_desc.xml
নামে একটি 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 নির্ভরতা আপডেট করুন
আমরা সুপারিশ করি যে আপনি আপনার মিডিয়া ব্রাউজার পরিষেবাটিকে একটি পৃথক মডিউলে রাখুন যা আপনি আপনার ফোন অ্যাপ এবং আপনার স্বয়ংচালিত মডিউলের মধ্যে ভাগ করেন৷ আপনি যদি এই পদ্ধতিটি ব্যবহার করেন, তাহলে শেয়ার করা মডিউলটি অন্তর্ভুক্ত করতে আপনাকে আপনার স্বয়ংচালিত মডিউল আপডেট করতে হবে, যেমনটি নিম্নলিখিত স্নিপেটে দেখানো হয়েছে:
গ্রোভি
buildscript { ... dependencies { ... implementation project(':shared_module_name') } }
কোটলিন
buildscript { ... dependencies { ... implementation(project(":shared_module_name")) } }
সেটিংস এবং সাইন-ইন কার্যক্রম বাস্তবায়ন করুন
আপনার মিডিয়া ব্রাউজার পরিষেবা ছাড়াও, আপনি আপনার Android Automotive OS অ্যাপের জন্য যানবাহন-অপ্টিমাইজ করা সেটিংস এবং সাইন-ইন কার্যক্রমও প্রদান করতে পারেন। এই কার্যকলাপগুলি আপনাকে অ্যাপ্লিকেশান কার্যকারিতা প্রদান করতে দেয় যা Android Media API-তে অন্তর্ভুক্ত নয়৷
যদি আপনার 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
ইন্টেন্ট পাঠায় যা আপনার অ্যাপকে আপনার সেটিংস কার্যকলাপ শুরু করতে বলে।
এই বিভাগের বাকি অংশটি দেখায় কিভাবে আপনি আপনার অ্যাপের জন্য একটি সেটিংস কার্যকলাপ বাস্তবায়ন করতে ইউনিভার্সাল অ্যান্ড্রয়েড মিউজিক প্লেয়ার (ইউএএমপি) নমুনা অ্যাপ থেকে কোড গ্রহণ করতে পারেন।
শুরু করতে, নমুনা কোড ডাউনলোড করুন:
# 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/src/main/res/xml/preferences.xml
এর মত একটি পছন্দের গাছ সংজ্ঞায়িত করুন। একটি
PreferenceFragmentCompat
প্রয়োগ করুন যা আপনার সেটিংস কার্যকলাপ প্রদর্শন করে। আরও তথ্যের জন্য UAMP-এSettingsFragment.kt
এবংSettingsActivity.kt
ফাইল এবং Android সেটিংস গাইড দেখুন।
আপনি আপনার সেটিংস কার্যকলাপ বাস্তবায়ন করার সময়, পছন্দ গ্রন্থাগারের কিছু উপাদান ব্যবহার করার জন্য এই সেরা অনুশীলনগুলি বিবেচনা করুন:
- আপনার সেটিংস ক্রিয়াকলাপে মূল দৃশ্যের নীচে গভীরতার দুটি স্তরের বেশি না রাখুন৷
- একটি
DropDownPreference
ব্যবহার করবেন না। পরিবর্তে একটিListPreference
ব্যবহার করুন। - সাংগঠনিক উপাদান:
-
PreferenceScreen
- এটি আপনার পছন্দের গাছের শীর্ষ স্তর হতে হবে।
-
PreferenceCategory
-
Preference
বস্তুকে একসাথে গোষ্ঠী করতে ব্যবহৃত হয়। - একটি
title
অন্তর্ভুক্ত করুন।
-
-
- নিম্নলিখিত সমস্ত উপাদানগুলিতে একটি
key
এবংtitle
অন্তর্ভুক্ত করুন। আপনি একটিsummary
, একটিicon
বা উভয়ই অন্তর্ভুক্ত করতে পারেন:-
Preference
- আপনার
PreferenceFragmentCompat
বাস্তবায়নেরonPreferenceTreeClick()
কলব্যাকে যুক্তিটি কাস্টমাইজ করুন।
- আপনার
-
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()
পদ্ধতিতে,sendResult()
পদ্ধতি ব্যবহার করেnull
ফলাফল পাঠান। -
setState()
পদ্ধতি ব্যবহার করে মিডিয়া সেশনেরPlaybackStateCompat
কেSTATE_ERROR
এ সেট করুন। এটি Android Automotive OS কে বলে যে ত্রুটিটি সমাধান না হওয়া পর্যন্ত অন্য কোন অপারেশন করা যাবে না। - মিডিয়া সেশনের
PlaybackStateCompat
ত্রুটি কোডERROR_CODE_AUTHENTICATION_EXPIRED
এ সেট করুন। এটি Android Automotive OS কে বলে যে ব্যবহারকারীকে প্রমাণীকরণ করতে হবে। -
setErrorMessage()
পদ্ধতি ব্যবহার করে মিডিয়া সেশনেরPlaybackStateCompat
ত্রুটি বার্তা সেট করুন। কারণ এই ত্রুটি বার্তাটি ব্যবহারকারী-মুখী, ব্যবহারকারীর বর্তমান লোকেলের জন্য এটি স্থানীয়করণ করুন। setExtras()
পদ্ধতি ব্যবহার করে মিডিয়া সেশনেরPlaybackStateCompat
অতিরিক্ত সেট করুন। নিম্নলিখিত দুটি কী অন্তর্ভুক্ত করুন:-
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
দ্বারা উল্লেখ করা বোতামটি আলতো চাপে।
-
নিম্নলিখিত কোড স্নিপেট দেখায় কিভাবে আপনার অ্যাপ ব্যবহার করার আগে ব্যবহারকারীকে সাইন ইন করতে হবে:
কোটলিন
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)
জাভা
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);
ব্যবহারকারী সফলভাবে প্রমাণীকরণের পরে, STATE_ERROR
ব্যতীত অন্য কোনো অবস্থায় PlaybackStateCompat
সেট করুন, তারপর কার্যকলাপের finish()
পদ্ধতিতে কল করে ব্যবহারকারীকে অ্যান্ড্রয়েড অটোমোটিভ ওএস-এ ফিরিয়ে নিয়ে যান।
আপনার সাইন-ইন কার্যকলাপ বাস্তবায়ন করুন
Google বিভিন্ন ধরনের পরিচয় টুল অফার করে যা আপনি ব্যবহারকারীদের তাদের গাড়িতে আপনার অ্যাপে সাইন ইন করতে সাহায্য করতে ব্যবহার করতে পারেন। কিছু টুল, যেমন ফায়ারবেস প্রমাণীকরণ, ফুল-স্ট্যাক টুলকিট প্রদান করে যা আপনাকে কাস্টমাইজড প্রমাণীকরণ অভিজ্ঞতা তৈরি করতে সাহায্য করতে পারে। ব্যবহারকারীদের জন্য নিরবিচ্ছিন্ন সাইন-ইন অভিজ্ঞতা তৈরি করতে আপনাকে সাহায্য করার জন্য অন্যান্য সরঞ্জামগুলি একজন ব্যবহারকারীর বিদ্যমান শংসাপত্র বা অন্যান্য প্রযুক্তির ব্যবহার করে।
নিম্নলিখিত সরঞ্জামগুলি আপনাকে ব্যবহারকারীদের জন্য একটি সহজ সাইন-ইন অভিজ্ঞতা তৈরি করতে সাহায্য করতে পারে যারা আগে অন্য ডিভাইসে সাইন ইন করেছেন:
- ওয়ান ট্যাপ সাইন-ইন এবং সাইন-আপ: আপনি যদি ইতিমধ্যেই আপনার ফোন অ্যাপের মতো অন্যান্য ডিভাইসের জন্য ওয়ান ট্যাপ প্রয়োগ করে থাকেন, তাহলে বিদ্যমান ওয়ান ট্যাপ ব্যবহারকারীদের সমর্থন করার জন্য আপনার Android Automotive OS অ্যাপের জন্য এটি প্রয়োগ করুন।
- Google সাইন-ইন: আপনি যদি ইতিমধ্যেই আপনার ফোন অ্যাপের মতো অন্যান্য ডিভাইসে Google সাইন-ইন প্রয়োগ করে থাকেন, তাহলে বিদ্যমান Google সাইন-ইন ব্যবহারকারীদের সমর্থন করার জন্য আপনার Android Automotive OS অ্যাপের জন্য Google সাইন-ইন প্রয়োগ করুন।
- Google এর সাথে অটোফিল: ব্যবহারকারীরা যদি তাদের অন্যান্য অ্যান্ড্রয়েড ডিভাইসে Google-এর সাথে অটোফিল নির্বাচন করে থাকেন, তাহলে তাদের শংসাপত্রগুলি Google পাসওয়ার্ড ম্যানেজারে সংরক্ষিত হয়। যখন সেই ব্যবহারকারীরা আপনার Android Automotive OS অ্যাপে সাইন ইন করেন, তখন Google-এর সাথে অটোফিল প্রাসঙ্গিক সংরক্ষিত শংসাপত্রের পরামর্শ দেয়। Google-এর সাথে অটোফিল ব্যবহার করার জন্য কোনো অ্যাপ্লিকেশন ডেভেলপমেন্ট প্রচেষ্টার প্রয়োজন নেই। যাইহোক, অ্যাপ্লিকেশন বিকাশকারীরা তাদের অ্যাপ্লিকেশনগুলিকে আরও ভাল মানের ফলাফলের জন্য অপ্টিমাইজ করতে পারে৷ Android Automotive OS সহ Android 8.0 (API লেভেল 26) বা তার উপরে চলমান সমস্ত ডিভাইসে Google-এর সাথে অটোফিল সমর্থিত।
অ্যাকাউন্ট ম্যানেজার ব্যবহার করুন
Android Automotive OS অ্যাপ্লিকেশানগুলির প্রমাণীকরণ আছে তাদের অবশ্যই AccountManager ব্যবহার করতে হবে, নিম্নলিখিত কারণে:
- আরও ভাল UX এবং অ্যাকাউন্ট পরিচালনার সহজতা: ব্যবহারকারীরা সাইন-ইন এবং সাইন-আউট সহ সিস্টেম সেটিংসের অ্যাকাউন্ট মেনু থেকে সহজেই তাদের সমস্ত অ্যাকাউন্ট পরিচালনা করতে পারে৷
- "অতিথি" অভিজ্ঞতা: গাড়িগুলি ভাগ করা ডিভাইস, যার অর্থ OEMগুলি গাড়িতে "অতিথি" অভিজ্ঞতা সক্ষম করতে পারে, যেখানে অ্যাকাউন্টগুলি যোগ করা যায় না৷
AccountManager
জন্যDISALLOW_MODIFY_ACCOUNTS
ব্যবহার করে এই সীমাবদ্ধতা অর্জন করা হয়েছে।
অনুমতি
আপনি যদি ব্যবহারকারীর কাছ থেকে অনুমতির অনুরোধ করতে চান, তাহলে পূর্ববর্তী বিভাগে দেখানো অ্যাক্টিভিটি ওয়ার্কফ্লো ডায়াগ্রামে প্রমাণীকরণ কার্যকলাপ বা সেটিংস কার্যকলাপের মতো একই প্রবাহ ব্যবহার করুন।
মিডিয়া হোস্ট ইঙ্গিত পড়ুন
আপনার মিডিয়া ব্রাউজার পরিষেবার সাথে সংযোগকারী সিস্টেম অ্যাপ্লিকেশনের (এর সংস্করণ সহ) উপর নির্ভর করে, আপনার অ্যাপ্লিকেশন নিম্নলিখিত অতিরিক্তগুলি পেতে পারে:
ত্রুটি হ্যান্ডলিং
অ্যান্ড্রয়েড অটোমোটিভ ওএস-এ মিডিয়া অ্যাপের ত্রুটি মিডিয়া সেশনের PlaybackStateCompat
মাধ্যমে যোগাযোগ করা হয়। সমস্ত ত্রুটির জন্য, PlaybackStateCompat
কম্প্যাটে একটি উপযুক্ত ত্রুটি কোড এবং ত্রুটি বার্তা সেট করুন। এর ফলে UI-তে একটি 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
হিসাবে উপস্থিত হয় এবং গাড়িটি থামলেই ব্যবহারকারীরা সমাধান করতে পারে৷
পরীক্ষার ত্রুটির ক্ষেত্রে
যাচাই করুন যে আপনার অ্যাপ্লিকেশানটি সহ সমস্ত পরিস্থিতিতে ত্রুটিগুলিকে সুন্দরভাবে পরিচালনা করে:
- আপনার পণ্যের বিভিন্ন স্তর: উদাহরণস্বরূপ, বিনামূল্যে বনাম প্রিমিয়াম বা সাইন ইন বনাম সাইন আউট
- বিভিন্ন ড্রাইভের অবস্থা: উদাহরণস্বরূপ, পার্ক করা বনাম ড্রাইভিং
- বিভিন্ন সংযোগের অবস্থা: উদাহরণস্বরূপ, অনলাইন বনাম অফলাইন
অন্যান্য বিবেচনা
আপনার অ্যান্ড্রয়েড অটোমোটিভ ওএস অ্যাপ ডেভেলপ করার সময় এই অন্যান্য বিবেচনার কথা মাথায় রাখুন:
অফলাইন বিষয়বস্তু
প্রযোজ্য হলে, অফলাইন প্লেব্যাক সমর্থন প্রয়োগ করুন। অ্যান্ড্রয়েড অটোমোটিভ ওএস সহ গাড়িগুলির নিজস্ব ডেটা সংযোগ থাকবে বলে আশা করা হচ্ছে, যার অর্থ একটি ডেটা প্ল্যান গাড়ির খরচের মধ্যে অন্তর্ভুক্ত করা হয়েছে বা ব্যবহারকারীর দ্বারা অর্থ প্রদান করা হয়েছে৷ যাইহোক, গাড়ির মোবাইল ডিভাইসের তুলনায় আরো পরিবর্তনশীল সংযোগ থাকবে বলে আশা করা হচ্ছে।
আপনার অফলাইন সমর্থন কৌশল বিবেচনা করার সময় এখানে কয়েকটি বিষয় মনে রাখতে হবে:
- কন্টেন্ট ডাউনলোড করার সর্বোত্তম সময় হল আপনার অ্যাপ ব্যবহারের সময়।
- অনুমান করবেন না যে ওয়াইফাই উপলব্ধ। একটি গাড়ি কখনই ওয়াইফাই রেঞ্জে নাও আসতে পারে, বা OEM সেলুলার নেটওয়ার্কের পক্ষে ওয়াইফাই অক্ষম করতে পারে।
- ব্যবহারকারীরা ব্যবহার করতে চান এমন বিষয়বস্তু স্মার্টলি ক্যাশে করা ঠিক হলেও, আমরা সুপারিশ করি যে আপনি ব্যবহারকারীকে আপনার সেটিংস কার্যকলাপের মাধ্যমে এই আচরণটি পরিবর্তন করতে দিন।
- গাড়ির ডিস্কের স্থান পরিবর্তিত হয়, তাই ব্যবহারকারীদের অফলাইন সামগ্রী মুছে ফেলার একটি উপায় দিন, যেমন আপনার সেটিংস কার্যকলাপের একটি বিকল্পের মাধ্যমে৷
ওয়েবভিউ সমর্থন
WebViews Android Automotive OS-এ সমর্থিত কিন্তু শুধুমাত্র আপনার সেটিংস এবং সাইন-ইন কার্যকলাপের জন্য অনুমোদিত। ওয়েবভিউ ব্যবহার করে এমন ক্রিয়াকলাপগুলির অবশ্যই WebView এর বাইরে একটি "ক্লোজ" বা "ব্যাক" সামর্থ্য থাকতে হবে।
WebViews-এর জন্য গ্রহণযোগ্য ব্যবহারের ক্ষেত্রে কিছু উদাহরণ এখানে দেওয়া হল:
- আপনার সেটিংস কার্যকলাপে আপনার গোপনীয়তা নীতি, পরিষেবার শর্তাবলী বা অন্যান্য আইনি-সম্পর্কিত লিঙ্কগুলি প্রদর্শন করা।
- আপনার সাইন-ইন কার্যকলাপে একটি ওয়েব-ভিত্তিক প্রবাহ।
একটি WebView ব্যবহার করার সময়, আপনি Javascript সক্রিয় করতে পারেন।
আপনার WebView সুরক্ষিত করুন
আপনার ওয়েবভিউ বৃহত্তর ইন্টারনেটে প্রবেশের বিন্দু নয় তা নিশ্চিত করার জন্য সম্ভাব্য সমস্ত সতর্কতা অবলম্বন করুন। কিভাবে loadUrl()
কলে ব্যবহৃত URL-এ WebView লক করা যায় এবং পুনঃনির্দেশ প্রতিরোধ করা যায় তার উদাহরণের জন্য নিম্নলিখিত কোড স্নিপেটটি দেখুন। আমরা অত্যন্ত সুপারিশ করি যে আপনি যখন সম্ভব হয় তখন এই ধরনের সুরক্ষা প্রয়োগ করুন, যেমন আইনি-সম্পর্কিত লিঙ্কগুলি প্রদর্শন করার সময়।
কোটলিন
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 }
জাভা
@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) বিতরণ করেন, তাই আপনি আপনার মোবাইল অ্যাপ থেকে প্যাকেজ নামটি পুনরায় ব্যবহার করতে পারেন বা একটি নতুন প্যাকেজ নাম তৈরি করতে পারেন৷ আপনি যদি একটি ভিন্ন প্যাকেজের নাম ব্যবহার করেন, আপনার অ্যাপে দুটি আলাদা প্লে স্টোর তালিকা রয়েছে। আপনি যদি আপনার বর্তমান প্যাকেজের নাম পুনরায় ব্যবহার করেন, আপনার অ্যাপের উভয় প্ল্যাটফর্মে একটি একক তালিকা রয়েছে।
এটি মূলত একটি ব্যবসায়িক সিদ্ধান্ত। উদাহরণস্বরূপ, যদি আপনার মোবাইল অ্যাপে একটি টিম কাজ করে এবং একটি পৃথক দল আপনার Android Automotive OS অ্যাপে কাজ করে, তাহলে আলাদা প্যাকেজের নাম রাখা এবং প্রতিটি দলকে নিজস্ব Play Store তালিকা পরিচালনা করতে দেওয়া বোধগম্য হতে পারে। উভয় পদ্ধতি ব্যবহার করার জন্য প্রয়োজনীয় প্রযুক্তিগত প্রচেষ্টার মধ্যে একটি বড় পার্থক্য নেই।
নিম্নলিখিত সারণীটি আপনার বর্তমান প্যাকেজের নাম রাখা এবং একটি নতুন প্যাকেজ নাম ব্যবহার করার মধ্যে কিছু অন্যান্য মূল পার্থক্যকে সংক্ষিপ্ত করে:
বৈশিষ্ট্য | একই প্যাকেজের নাম | নতুন প্যাকেজের নাম |
---|---|---|
দোকান তালিকা | একক | একাধিক |
মিরর ইনস্টল | হ্যাঁ: সেটআপ উইজার্ড চলাকালীন "দ্রুত অ্যাপ পুনরায় ইনস্টল করুন" | না |
প্লে স্টোর পর্যালোচনা প্রক্রিয়া | রিভিউ ব্লক করা: যদি একটি APK এর জন্য রিভিউ ব্যর্থ হয়, তাহলে একই রিলিজে জমা দেওয়া অন্যান্য APK ব্লক করা হয় | স্বতন্ত্র পর্যালোচনা |
পরিসংখ্যান, মেট্রিক্স, এবং গুরুত্বপূর্ণ | সম্মিলিত: আপনি স্বয়ংচালিত-নির্দিষ্ট ডেটার জন্য ফিল্টার করতে পারেন। | আলাদা |
ইনডেক্সিং এবং সার্চ র্যাঙ্কিং | বর্তমান স্ট্যান্ডিং বন্ধ করুন | কোন ক্যারিওভার নেই |
অন্যান্য অ্যাপের সাথে একীভূত হচ্ছে | সম্ভবত কোন পরিবর্তনের প্রয়োজন নেই, ধরে নিচ্ছি যে মিডিয়া কোড উভয় APK এর মধ্যে ভাগ করা হয়েছে | Google সহকারীর সাথে ইউআরআই প্লেব্যাকের মতো সংশ্লিষ্ট অ্যাপ আপডেট করতে হতে পারে। |
প্রায়শই জিজ্ঞাসিত প্রশ্ন
Android Automotive OS সম্পর্কে প্রায়শই জিজ্ঞাসিত কিছু প্রশ্নের উত্তরের জন্য নিম্নলিখিত বিভাগগুলি দেখুন৷
হার্ডওয়্যার
আমার অ্যাপ কি মাইক্রোফোনে অ্যাক্সেস পেতে পারে?
Android 10 (API লেভেল 29) বা উচ্চতরকে লক্ষ্য করে এমন অ্যাপগুলির জন্য, শেয়ারিং অডিও ইনপুট ডকুমেন্টেশন দেখুন। API স্তর 29 এর আগে এটি সম্ভব নয়।
আমরা কোন গাড়ির APIগুলিতে অ্যাক্সেস পেতে পারি এবং কীভাবে?
আপনি সীমিত APIs যে OEM দ্বারা উন্মুক্ত করা হয়. আপনি কীভাবে এই APIগুলি অ্যাক্সেস করেন তা প্রমিত করার জন্য প্রক্রিয়াগুলি তৈরি করা হচ্ছে৷
অ্যাপগুলি CarPropertyManager
এ SetProperty()
এবং GetProperty()
ব্যবহার করে গাড়ির API অ্যাক্সেস করতে পারে। সমস্ত উপলব্ধ বৈশিষ্ট্যগুলির একটি তালিকা দেখতে উত্স কোড বা রেফারেন্স ডকুমেন্টেশন পড়ুন৷ যদি সম্পত্তিটি @SystemApi
সাথে টীকা করা হয় তবে এটি প্রিলোড করা সিস্টেম অ্যাপের মধ্যে সীমাবদ্ধ।
কি ধরনের অডিও কোডেক সমর্থিত?
অ্যান্ড্রয়েড সিডিডি-তে অডিও কোডেক বিবরণ পড়ুন।
Widevine DRM সমর্থিত?
হ্যাঁ। ওয়াইডিভাইন ডিআরএম সমর্থিত।
উন্নয়ন এবং পরীক্ষা
তৃতীয় পক্ষের SDK এবং লাইব্রেরি ব্যবহার করার জন্য কোন বিধিনিষেধ বা সুপারিশ আছে?
তৃতীয় পক্ষের SDK এবং লাইব্রেরি ব্যবহার করার বিষয়ে আমাদের কোনো নির্দিষ্ট নির্দেশিকা নেই। আপনি যদি থার্ড-পার্টি SDK এবং লাইব্রেরি ব্যবহার করা বেছে নেন, তাহলেও গাড়ি অ্যাপের গুণমানের প্রয়োজনীয়তা মেনে চলার জন্য আপনি দায়ী।
আমি কি ফোরগ্রাউন্ড পরিষেবা ব্যবহার করতে পারি?
ফোরগ্রাউন্ড পরিষেবার জন্য একমাত্র অনুমোদিত ব্যবহারের ক্ষেত্রে অফলাইন ব্যবহারের জন্য সামগ্রী ডাউনলোড করা। যদি আপনার কাছে একটি ফোরগ্রাউন্ড পরিষেবার জন্য অন্য একটি ব্যবহার-কেস থাকে যার জন্য আপনি সমর্থন দেখতে চান, তাহলে Android Automotive OS আলোচনা গোষ্ঠী ব্যবহার করে আমাদের সাথে যোগাযোগ করুন৷
Android Automotive OS অ্যাপ প্রকাশ করা হচ্ছে
আমি কিভাবে Google Play Console ব্যবহার করে আমার Android Automotive OS অ্যাপ প্রকাশ করব?
Google Play Console ব্যবহার করে কীভাবে আপনার Android Automotive OS অ্যাপ প্রকাশ করবেন তার বিশদ বিবরণের জন্য, গাড়িতে বিতরণ দেখুন।
অতিরিক্ত সম্পদ
Android Automotive OS সম্পর্কে আরও জানতে, নিম্নলিখিত অতিরিক্ত সংস্থানগুলি দেখুন৷
নমুনা
গাইড
- ড্রাইভিং জন্য ডিজাইন
- মিডিয়া কন্ট্রোলার পরীক্ষা অ্যাপ ব্যবহার করে
- Android Automotive OS-এ বিজ্ঞপ্তি
- গাড়ির জন্য Android অ্যাপের গুণমান
ব্লগ
- ডেভেলপারদের জন্য Android Automotive OS আপডেট
- অ্যান্ড্রয়েড অটোমোটিভ ওএসের জন্য অ্যাপস তৈরি করা হচ্ছে
ভিডিও
- কিভাবে গাড়ির জন্য মিডিয়া অ্যাপস তৈরি করবেন (Android Dev Summit '19)
- কিভাবে গাড়ির জন্য অ্যান্ড্রয়েড অ্যাপস তৈরি করবেন (Google I/O'19)
একটি Android Automotive OS Media সমস্যা রিপোর্ট করুন
অ্যান্ড্রয়েড অটোমোটিভ ওএস-এর জন্য আপনার মিডিয়া অ্যাপ ডেভেলপ করার সময় আপনি যদি কোনও সমস্যার সম্মুখীন হন, আপনি Google ইস্যু ট্র্যাকার ব্যবহার করে রিপোর্ট করতে পারেন। ইস্যু টেমপ্লেটে অনুরোধ করা সমস্ত তথ্য পূরণ করতে ভুলবেন না।
একটি নতুন সমস্যা ফাইল করার আগে, এটি ইতিমধ্যেই সমস্যা তালিকায় রিপোর্ট করা আছে কিনা তা পরীক্ষা করে দেখুন। আপনি সাবস্ক্রাইব করতে পারেন এবং ট্র্যাকারে একটি সমস্যার জন্য তারকা ক্লিক করে সমস্যার জন্য ভোট দিতে পারেন। আরও তথ্যের জন্য, একটি ইস্যুতে সদস্যতা নেওয়া দেখুন।