ইনস্ট্রুমেন্ট ক্লাস্টার এপিআই (একটি অ্যান্ড্রয়েড এপিআই) ব্যবহার করুন ন্যাভিগেশন অ্যাপ্লিকেশানগুলি, Google মানচিত্র সহ, একটি গাড়ির একটি সেকেন্ডারি ডিসপ্লেতে, যেমন ইন্সট্রুমেন্ট প্যানেলে স্টিয়ারিং হুইলের পিছনে। এই পৃষ্ঠাটি বর্ণনা করে যে কীভাবে সেই সেকেন্ডারি ডিসপ্লে নিয়ন্ত্রণ করতে একটি পরিষেবা তৈরি করতে হয় এবং পরিষেবাটিকে CarService
এর সাথে একীভূত করতে হয় যাতে নেভিগেশন অ্যাপগুলি একটি ব্যবহারকারী ইন্টারফেস প্রদর্শন করতে পারে।
পরিভাষা
নিম্নলিখিত পদ এই পৃষ্ঠায় ব্যবহার করা হয়.
CarManager
এর একটি উদাহরণ যা বাহ্যিক অ্যাপগুলিকে ইনস্ট্রুমেন্ট ক্লাস্টারে একটি অ্যাক্টিভিটি চালু করতে সক্ষম করে এবং যখন ইনস্ট্রুমেন্ট ক্লাস্টার ক্রিয়াকলাপগুলি প্রদর্শনের জন্য প্রস্তুত থাকে তখন কলব্যাক গ্রহণ করে৷android:singleUser
অ্যাট্রিবিউট সহ একটি Android পরিষেবা৷ যে কোনো সময়ে, পরিষেবার সর্বাধিক একটি দৃষ্টান্ত অ্যান্ড্রয়েড সিস্টেমে চলে৷পূর্বশর্ত
আপনি চালিয়ে যাওয়ার আগে, এই উপাদানগুলি নিশ্চিত করুন:
- অ্যান্ড্রয়েড উন্নয়ন পরিবেশ। অ্যান্ড্রয়েড ডেভেলপমেন্ট এনভায়রনমেন্ট সেট আপ করতে, বিল্ড প্রয়োজনীয়তা দেখুন।
- অ্যান্ড্রয়েড সোর্স কোড ডাউনলোড করুন। পাই-কার-রিলিজ শাখা (বা পরে) থেকে Android সোর্স কোডের সর্বশেষ সংস্করণটি https://android.googlesource.com- এ পান।
- হেড ইউনিট (HU)। একটি Android ডিভাইস যা Android 9 (বা পরবর্তীতে) চালাতে সক্ষম। এই ডিভাইসটির নিজস্ব ডিসপ্লে থাকতে হবে এবং Android এর নতুন বিল্ডের সাথে ডিসপ্লে ফ্ল্যাশ করতে সক্ষম হতে হবে।
- ইন্সট্রুমেন্ট ক্লাস্টার নিম্নলিখিতগুলির মধ্যে একটি:
- HU এর সাথে সংযুক্ত শারীরিক মাধ্যমিক প্রদর্শন। যদি ডিভাইস হার্ডওয়্যার এবং কার্নেল একাধিক প্রদর্শনের পরিচালনা সমর্থন করে।
- স্বাধীন ইউনিট। যে কোনো কম্পিউটেশনাল ইউনিট একটি নেটওয়ার্ক সংযোগের মাধ্যমে HU এর সাথে সংযুক্ত, তার নিজস্ব ডিসপ্লেতে একটি ভিডিও স্ট্রিম গ্রহণ এবং প্রদর্শন করতে সক্ষম।
- এমুলেটেড ডিসপ্লে। বিকাশের সময়, আপনি এই অনুকরণ করা পরিবেশগুলির মধ্যে একটি ব্যবহার করতে পারেন:
- সিমুলেটেড সেকেন্ডারি ডিসপ্লে। যেকোন AOSP অ্যান্ড্রয়েড ডিস্ট্রিবিউশনে একটি সিমুলেটেড সেকেন্ডারি ডিসপ্লে সক্ষম করতে, সেটিংস সিস্টেম অ্যাপে বিকাশকারী বিকল্প সেটিংসে যান এবং তারপরে সেকেন্ডারি ডিসপ্লে সিমুলেট করুন নির্বাচন করুন এই কনফিগারেশনটি একটি ফিজিক্যাল সেকেন্ডারি ডিসপ্লে সংযুক্ত করার সমতুল্য, এই ডিসপ্লেটি সীমাবদ্ধতার সাথে প্রাথমিক প্রদর্শন।
- অনুকরণ করা যন্ত্র ক্লাস্টার। AAOS-এর সাথে অন্তর্ভুক্ত অ্যান্ড্রয়েড এমুলেটর ClusterRenderingService- এর সাথে একটি ইন্সট্রুমেন্ট ক্লাস্টার প্রদর্শন করার বিকল্প প্রদান করে।
ইন্টিগ্রেশন আর্কিটেকচার
ইন্টিগ্রেশন উপাদান
ইনস্ট্রুমেন্ট ক্লাস্টার এপিআই-এর যেকোনো একীকরণ এই তিনটি উপাদান নিয়ে গঠিত:
-
CarService
- নেভিগেশন অ্যাপস
- OEM উপকরণ ক্লাস্টার পরিষেবা
কারসার্ভিস
CarService
নেভিগেশন অ্যাপ এবং গাড়ির মধ্যে মধ্যস্থতা করে, এটি নিশ্চিত করে যে কোনও নির্দিষ্ট সময়ে শুধুমাত্র একটি নেভিগেশন অ্যাপ সক্রিয় থাকে এবং শুধুমাত্র android.car.permission.CAR_INSTRUMENT_CLUSTER_CONTROL
অনুমতি সহ অ্যাপগুলি গাড়িতে ডেটা পাঠাতে পারে।
CarService
সমস্ত গাড়ি-নির্দিষ্ট পরিষেবা বুটস্ট্র্যাপ করে এবং ম্যানেজারদের একটি সিরিজের মাধ্যমে এই পরিষেবাগুলিতে অ্যাক্সেস প্রদান করে। পরিষেবাগুলির সাথে ইন্টারঅ্যাক্ট করতে, গাড়িতে চলমান অ্যাপগুলি এই পরিচালকদের অ্যাক্সেস করতে পারে৷
ইন্সট্রুমেন্ট ক্লাস্টার বাস্তবায়নের জন্য, স্বয়ংচালিত OEM-কে অবশ্যই InstrumentClusterRendererService-এর একটি কাস্টম বাস্তবায়ন তৈরি করতে হবে এবং ClusterRenderingService আপডেট করতে হবে।
একটি ইন্সট্রুমেন্ট ক্লাস্টার রেন্ডার করার সময়, বুট প্রক্রিয়া চলাকালীন CarService
InstrumentClusterService
এর বাস্তবায়ন সনাক্ত করতে ClusterRenderingService- এর InstrumentClusterRendererService
কীটি পড়ে। AOSP-তে, এই এন্ট্রি নেভিগেশন স্টেট API নমুনা ক্লাস্টার বাস্তবায়ন রেন্ডার পরিষেবার দিকে নির্দেশ করে:
<string name="instrumentClusterRendererService"> android.car.cluster/.ClusterRenderingService </string>
এই এন্ট্রিতে উল্লেখ করা পরিষেবাটি আরম্ভ করা হয়েছে এবং CarService
সাথে আবদ্ধ। যখন নেভিগেশন অ্যাপ্লিকেশানগুলি, Google মানচিত্রের মতো, একটি CarInstrumentClusterManager
জন্য অনুরোধ করে, CarService
একটি ম্যানেজার প্রদান করে যা আবদ্ধ InstrumentClusterRenderingService
থেকে ইনস্ট্রুমেন্ট ক্লাস্টার অবস্থা আপডেট করে। (এই ক্ষেত্রে, আবদ্ধ Android পরিষেবাগুলিকে বোঝায়।)
যন্ত্র ক্লাস্টার পরিষেবা
OEM-কে অবশ্যই একটি Android প্যাকেজ (APK) তৈরি করতে হবে যাতে ClusterRenderingService- এর একটি সাবক্লাস থাকে।
এই ক্লাস দুটি উদ্দেশ্য পরিবেশন করে:
- একটি ইন্টারফেস অ্যান্ড্রয়েড এবং ইনস্ট্রুমেন্ট ক্লাস্টার রেন্ডারিং ডিভাইস প্রদান করে (এই পৃষ্ঠার উদ্দেশ্য)।
- নেভিগেশন স্টেট আপডেট গ্রহণ করে এবং রেন্ডার করে, যেমন টার্ন-বাই-টার্ন নেভিগেশন নির্দেশিকা।
প্রথম উদ্দেশ্যের জন্য, InstrumentClusterRendererService
CarService
OEM বাস্তবায়নকে অবশ্যই গাড়ির কেবিনের স্ক্রীনে তথ্য রেন্ডার করতে ব্যবহৃত সেকেন্ডারি ডিসপ্লে শুরু করতে হবে এবং InstrumentClusterRendererService.setClusterActivityOptions()
এবং InstrumentClusterRendererService.setClusterActivityState()
.
দ্বিতীয় ফাংশনের জন্য, ইনস্ট্রুমেন্ট ক্লাস্টার পরিষেবাকে অবশ্যই ClusterRenderingService- এর একটি বাস্তবায়ন প্রদান করতে হবে ইন্টারফেস যা নেভিগেশন স্থিতি আপডেট ইভেন্টগুলি গ্রহণ করে, যা একটি eventType
হিসাবে এনকোড করা হয় এবং একটি বান্ডেলে এনকোড করা ইভেন্ট ডেটা।
ইন্টিগ্রেশন সিকোয়েন্স
নিম্নলিখিত চিত্রটি একটি নেভিগেশন অবস্থার বাস্তবায়নকে চিত্রিত করে যা আপডেটগুলি রেন্ডার করে:
এই চিত্রে, রঙগুলি নিম্নলিখিতগুলিকে নির্দেশ করে:
- হলুদ।
CarService
এবংCarNavigationStatusManager
অ্যান্ড্রয়েড প্ল্যাটফর্ম দ্বারা সরবরাহ করা হয়েছে। আরও জানতে, গাড়ি এবং CAR_NAVIGATION_SERVICE দেখুন। - সায়ান।
InstrumentClusterRendererService
OEM দ্বারা বাস্তবায়িত। - বেগুনি। Google এবং তৃতীয় পক্ষের বিকাশকারীদের দ্বারা বাস্তবায়িত ন্যাভিগেশন অ্যাপ।
- সবুজ।
CarAppFocusManager
। আরও জানতে, নীচে CarAppFocusManager API এবং CarAppFocusManager ব্যবহার করা দেখুন।
নেভিগেশন স্টেট তথ্য প্রবাহ এই ক্রম অনুসরণ করে:
-
CarService
InstrumentClusterRenderingService
শুরু করে। - আরম্ভ করার সময়,
InstrumentClusterRenderingService
এর সাথেCarService
আপডেট করে:- ইনস্ট্রুমেন্ট ক্লাস্টার প্রদর্শন বৈশিষ্ট্য, যেমন অস্পষ্ট সীমানা (পরে অস্পষ্ট সীমানা সম্পর্কে আরও বিশদ দেখুন)।
- ইনস্ট্রুমেন্ট ক্লাস্টার ডিসপ্লের ভিতরে ক্রিয়াকলাপ চালু করার জন্য প্রয়োজনীয় কার্যকলাপ বিকল্পগুলি। আরও জানতে, Activity Options দেখুন।
- একটি নেভিগেশন অ্যাপ (যেমন অ্যান্ড্রয়েড অটোমোটিভের জন্য Google মানচিত্র বা প্রয়োজনীয় অনুমতি সহ যেকোনো মানচিত্র অ্যাপ):
- car-lib থেকে কার ক্লাস ব্যবহার করে একটি
CarAppFocusManager
পায়। - পালাক্রমে দিকনির্দেশ শুরু হওয়ার আগে,
CarAppFocusManager.APP_FOCUS_TYPE_NAVIGATION
appType
প্যারামিটার হিসেবে পাস করতেCarAppFocusManager.requestFocus()
এ কল করুন।
- car-lib থেকে কার ক্লাস ব্যবহার করে একটি
-
CarAppFocusManager
এই অনুরোধটিCarService
কে জানায়। যদি মঞ্জুর করা হয়,CarService
নেভিগেশন অ্যাপ প্যাকেজ পরিদর্শন করে এবংandroid.car.cluster.NAVIGATION
বিভাগ দ্বারা চিহ্নিত একটি কার্যকলাপ সনাক্ত করে। - যদি পাওয়া যায়, নেভিগেশন অ্যাপটি অ্যাক্টিভিটি চালু করতে
InstrumentClusterRenderingService
দ্বারা রিপোর্ট করাActivityOptions
ব্যবহার করে এবং ইনস্ট্রুমেন্ট ক্লাস্টার ডিসপ্লে বৈশিষ্ট্যগুলিকে উদ্দেশ্যের অতিরিক্ত হিসেবে অন্তর্ভুক্ত করে।
API ইন্টিগ্রেট করুন
InstrumentClusterRenderingService
বাস্তবায়ন অবশ্যই:
- AndroidManifest.xml-এ নিম্নলিখিত মান যোগ করে সিঙ্গলটন পরিষেবা হিসাবে মনোনীত হন। ইন্সট্রুমেন্ট ক্লাস্টার পরিষেবার একটি একক অনুলিপি চালানো হয় তা নিশ্চিত করার জন্য এটি প্রয়োজনীয়, এমনকি প্রাথমিককরণ এবং ব্যবহারকারীর স্যুইচিংয়ের সময়ও:
android:singleUser="true"
-
BIND_INSTRUMENT_CLUSTER_RENDERER_SERVICE
সিস্টেম অনুমতি ধরে রাখুন। এটি গ্যারান্টি দেয় যে শুধুমাত্র Android সিস্টেম ইমেজের অংশ হিসাবে অন্তর্ভুক্ত ইনস্ট্রুমেন্ট ক্লাস্টার রেন্ডারিং পরিষেবাটিই কখনওCarService
দ্বারা আবদ্ধ থাকে:<uses-permission android:name="android.car.permission.BIND_INSTRUMENT_CLUSTER_RENDERER_SERVICE"/>
InstrumentClusterRenderingService প্রয়োগ করুন
পরিষেবা তৈরি করতে:
- ClusterRenderingService থেকে প্রসারিত একটি ক্লাস লিখুন এবং তারপর আপনার
AndroidManifest.xml
ফাইলে একটি সংশ্লিষ্ট এন্ট্রি যোগ করুন। এই ক্লাসটি ইনস্ট্রুমেন্ট ক্লাস্টার ডিসপ্লে নিয়ন্ত্রণ করে এবং ( ঐচ্ছিকভাবে ) নেভিগেশন স্টেট API ডেটা রেন্ডার করতে পারে। -
onCreate()
এর সময়, রেন্ডারিং হার্ডওয়্যারের সাথে যোগাযোগ শুরু করতে এই পরিষেবাটি ব্যবহার করুন। বিকল্প অন্তর্ভুক্ত:- যন্ত্র ক্লাস্টারের জন্য ব্যবহৃত গৌণ প্রদর্শন নির্ধারণ করুন।
- একটি ভার্চুয়াল ডিসপ্লে তৈরি করুন যাতে ইনস্ট্রুমেন্ট ক্লাস্টার অ্যাপ রেন্ডার করা ছবিকে একটি বাহ্যিক ইউনিটে (ভিডিও স্ট্রিমিং ফরম্যাট ব্যবহার করে, যেমন H.264) প্রেরণ করে।
- উপরে নির্দেশিত ডিসপ্লেটি প্রস্তুত হলে, এই পরিষেবাটিকে অবশ্যই
InstrumentClusterRenderingService#setClusterActivityLaunchOptions()
কল করে সঠিকActivityOptions
সংজ্ঞায়িত করতে হবে যা ইনস্ট্রুমেন্ট ক্লাস্টারে একটি কার্যকলাপ প্রদর্শন করতে ব্যবহার করা আবশ্যক৷ এই পরামিতি ব্যবহার করুন:-
category.
ক্লাস্টার রেন্ডারিং সার্ভিস । -
ActivityOptions.
একটিActivityOptions
উদাহরণ যা ইনস্ট্রুমেন্ট ক্লাস্টারে একটি কার্যকলাপ চালু করতে ব্যবহার করা যেতে পারে। উদাহরণস্বরূপ, AOSP-তে নমুনা ইনস্ট্রুমেন্ট ক্লাস্টার বাস্তবায়ন থেকে:getService().setClusterActivityLaunchOptions( CATEGORY_NAVIGATION, ActivityOptions.makeBasic() .setLaunchDisplayId(displayId));
-
- যখন ইন্সট্রুমেন্ট ক্লাস্টার ক্রিয়াকলাপ প্রদর্শনের জন্য প্রস্তুত হয়, তখন এই পরিষেবাটি অবশ্যই
InstrumentClusterRenderingService#setClusterActivityState()
চালু করতে হবে। এই পরামিতি ব্যবহার করুন:-
category
রেন্ডারিং সার্ভিস । - ClusterRenderingService- এর মাধ্যমে
state
বান্ডিল তৈরি করা হয়েছে। এই তথ্য প্রদান করতে ভুলবেন না:-
visible
ইনস্ট্রুমেন্ট ক্লাস্টারটিকে দৃশ্যমান এবং সামগ্রী প্রদর্শনের জন্য প্রস্তুত হিসাবে নির্দিষ্ট করে৷ -
unobscuredBounds
একটি আয়তক্ষেত্র যা ইন্সট্রুমেন্ট ক্লাস্টার ডিসপ্লের মধ্যে এলাকাটি সংজ্ঞায়িত করে যেখানে বিষয়বস্তু প্রদর্শন করা নিরাপদ। উদাহরণস্বরূপ, ডায়াল এবং গেজ দ্বারা আচ্ছাদিত এলাকা।
-
-
-
Service#dump()
পদ্ধতি ওভাররাইড করুন এবং ডিবাগিংয়ের জন্য দরকারী স্থিতি তথ্য রিপোর্ট করুন (আরো তথ্যের জন্য ডাম্পসি দেখুন)।
নমুনা InstrumentClusterRenderingService বাস্তবায়ন
নিম্নলিখিত উদাহরণটি একটি InstrumentClusterRenderingService
বাস্তবায়নের রূপরেখা দেয়, যা একটি দূরবর্তী শারীরিক প্রদর্শনে ইনস্ট্রুমেন্ট ক্লাস্টার সামগ্রী উপস্থাপন করার জন্য একটি VirtualDisplay
তৈরি করে।
বিকল্পভাবে, এই কোডটি HU এর সাথে সংযুক্ত একটি ফিজিক্যাল সেকেন্ডারি ডিসপ্লের displayId
পাস করতে পারে, যদি একটি উপলব্ধ বলে জানা যায়।
/** * Sample {@link InstrumentClusterRenderingService} implementation */ public class SampleClusterServiceImpl extends InstrumentClusterRenderingService { // Used to retrieve or create displays private final DisplayManager mDisplayManager; // Unique identifier for the display to be used for instrument // cluster private final String mUniqueId = UUID.randomUUID().toString(); // Format of the instrument cluster display private static final int DISPLAY_WIDTH = 1280; private static final int DISPLAY_HEIGHT = 720; private static final int DISPLAY_DPI = 320; // Area not covered by instruments private static final int DISPLAY_UNOBSCURED_LEFT = 40; private static final int DISPLAY_UNOBSCURED_TOP = 0; private static final int DISPLAY_UNOBSCURED_RIGHT = 1200; private static final int DISPLAY_UNOBSCURED_BOTTOM = 680; @Override public void onCreate() { super.onCreate(); // Create a virtual display to render instrument cluster activities on mDisplayManager = getSystemService(DisplayManager.class); VirtualDisplay display = mDisplayManager.createVirtualDisplay( mUniqueId, DISPLAY_WIDTH, DISPLAY_HEIGHT, DISPLAY_DPI, null, 0 /* flags */, null, null); // Do any additional initialization (e.g.: start a video stream // based on this virtual display to present activities on a remote // display). onDisplayReady(display.getDisplay()); } private void onDisplayReady(Display display) { // Report activity options that should be used to launch activities on // the instrument cluster. String category = CarInstrumentClusterManager.CATEGORY_NAVIGATION; ActionOptions options = ActivityOptions.makeBasic() .setLaunchDisplayId(display.getDisplayId()); setClusterActivityOptions(category, options); // Report instrument cluster state. Rect unobscuredBounds = new Rect(DISPLAY_UNOBSCURED_LEFT, DISPLAY_UNOBSCURED_TOP, DISPLAY_UNOBSCURED_RIGHT, DISPLAY_UNOBSCURED_BOTTOM); boolean visible = true; ClusterActivityState state = ClusterActivityState.create(visible, unobscuredBounds); setClusterActivityState(category, options); } }
CarAppFocusManager API ব্যবহার করুন
CarAppFocusManager API getAppTypeOwner()
নামে একটি পদ্ধতি প্রদান করে, যা OEM-এর দ্বারা লিখিত ক্লাস্টার পরিষেবাকে যে কোনো সময়ে কোন নেভিগেশন অ্যাপে নেভিগেশন ফোকাস আছে তা জানার অনুমতি দেয়। OEMs বিদ্যমান CarAppFocusManager#addFocusListener()
পদ্ধতি ব্যবহার করতে পারে এবং তারপর কোন অ্যাপে ফোকাস আছে তা জানতে getAppTypeOwner()
ব্যবহার করতে পারে। এই তথ্যের সাথে, OEMগুলি করতে পারে:
- ন্যাভিগেশন অ্যাপ হোল্ডিং ফোকাস দ্বারা প্রদত্ত ক্লাস্টার কার্যকলাপে ক্লাস্টারে দেখানো কার্যকলাপটি পরিবর্তন করুন।
- ফোকাসড নেভিগেশন অ্যাপে ক্লাস্টার অ্যাক্টিভিটি আছে কি না তা শনাক্ত করতে পারে। যদি ফোকাসড নেভিগেশন অ্যাপের কোনো ক্লাস্টার অ্যাক্টিভিটি না থাকে (অথবা যদি এই ধরনের অ্যাক্টিভিটি অক্ষম থাকে), তাহলে OEM গুলি এই সিগন্যালটি গাড়ি ডিআইএম-এ পাঠাতে পারে যাতে ক্লাস্টারের নেভিগেশন ফেসটি সম্পূর্ণভাবে এড়িয়ে যায়।
সক্রিয় নেভিগেশন বা ভয়েস কমান্ডের মতো বর্তমান অ্যাপ ফোকাস সেট করতে এবং শুনতে CarAppFocusManager
ব্যবহার করুন। সাধারণত এই ধরনের একটি অ্যাপের শুধুমাত্র একটি উদাহরণ সিস্টেমে সক্রিয়ভাবে চলছে (বা ফোকাসড)।
অ্যাপ ফোকাস পরিবর্তন শুনতে CarAppFocusManager#addFocusListener(..)
পদ্ধতি ব্যবহার করুন:
import android.car.CarAppFocusManager; ... Car car = Car.createCar(this); mAppFocusManager = (CarAppFocusManager)car.getCarManager(Car.APP_FOCUS_SERVICE); mAppFocusManager.addFocusListener(this, CarAppFocusManager.APP_FOCUS_TYPE_NAVIGATION); ... public void onAppFocusChanged(int appType, boolean active) { // Use the CarAppFocusManager#getAppTypeOwner(appType) method call // to retrieve a list of active package names }
CarAppFocusManager#getAppTypeOwner(..)
পদ্ধতিটি ফোকাসে থাকা প্রদত্ত অ্যাপের বর্তমান মালিকের প্যাকেজ নামগুলি পুনরুদ্ধার করতে ব্যবহার করুন৷ বর্তমান মালিক android:sharedUserId
বৈশিষ্ট্য ব্যবহার করলে এই পদ্ধতিটি একাধিক প্যাকেজের নাম ফেরত দিতে পারে।
import android.car.CarAppFocusManager; ... Car car = Car.createCar(this); mAppFocusManager = (CarAppFocusManager)car.getCarManager(Car.APP_FOCUS_SERVICE); List<String> focusOwnerPackageNames = mAppFocusManager.getAppTypeOwner( CarAppFocusManager.APP_FOCUS_TYPE_NAVIGATION); if (focusOwnerPackageNames == null || focusOwnerPackageNames.isEmpty()) { // No Navigation app has focus // OEM may choose to show their default cluster view } else { // focusOwnerPackageNames // Use the PackageManager to retrieve the cluster activity for the package(s) // returned in focusOwnerPackageNames } ...
পরিশিষ্ট: নমুনা অ্যাপ্লিকেশন ব্যবহার করুন
AOSP একটি নমুনা অ্যাপ প্রদান করে যা নেভিগেশন স্টেট API প্রয়োগ করে।
এই নমুনা অ্যাপ্লিকেশন চালানোর জন্য:
- একটি সমর্থিত HU-তে Android Auto তৈরি এবং ফ্ল্যাশ করুন। আপনার ডিভাইসের জন্য নির্দিষ্ট Android বিল্ডিং এবং ফ্ল্যাশিং নির্দেশাবলী ব্যবহার করুন। নির্দেশাবলীর জন্য, রেফারেন্স বোর্ড ব্যবহার করা দেখুন।
- HU এর সাথে একটি ফিজিক্যাল সেকেন্ডারি ডিসপ্লে সংযুক্ত করুন (যদি সমর্থিত হয়) অথবা ভার্চুয়াল সেকেন্ডারি HU চালু করুন:
- সেটিংস অ্যাপে ডেভেলপার মোড নির্বাচন করুন।
- সেটিংস > সিস্টেম > অ্যাডভান্সড > ডেভেলপার অপশন > সেকেন্ডারি ডিসপ্লে অনুকরণে যান।
- HU রিবুট করুন
- KitchenSink অ্যাপ চালু করতে:
- ড্রয়ার খুলুন।
- Inst যান. ক্লাস্টার
- মেটাডেটা শুরু করুন ক্লিক করুন।
KitchenSink নেভিগেশন ফোকাসের অনুরোধ করে, যা DirectRenderingCluster
পরিষেবাকে ইন্সট্রুমেন্ট ক্লাস্টারে একটি উপহাস করা ইউজার ইন্টারফেস প্রদর্শনের নির্দেশ দেয়।