এখন যেহেতু কার UI লাইব্রেরির উপাদান এবং সংস্থানগুলি অ্যাপগুলিতে, এই অ্যাপগুলিকে কাস্টমাইজ করার জন্য, OEMগুলিকে অবশ্যই দুটি ওভারলে প্রদান করতে হবে:
বিল্ড-টাইম ওভারলে রানটাইম রিসোর্স ওভারলে (RROs) এর জন্য প্রয়োজনীয় কোনো সংস্থান যোগ করে। এর মধ্যে রয়েছে:
- অঙ্কনযোগ্য
- শৈলী (উদাহরণস্বরূপ, পাঠ্য উপস্থিতি)
- শেয়ার করা সম্পদ (উদাহরণস্বরূপ, রং)
RRO ওভারলে ফোল্ডারে প্রতি টার্গেট অ্যাপে একটি RRO তৈরি করতে ব্যবহৃত সম্পদ রয়েছে। এই সম্পদগুলি শুধুমাত্র উল্লেখ করতে পারে:
- একই RRO-এর মধ্যে সংজ্ঞায়িত মান (উদাহরণস্বরূপ, একটি রঙের জন্য এটি একটি হেক্সাডেসিমেল মান হবে)।
- Android ফ্রেমওয়ার্ক সংস্থান (উদাহরণস্বরূপ,
@android:color/accent)। - উপরের বিল্ড-টাইম ওভারলেতে সংজ্ঞায়িত একটি সংস্থান।
সাধারণ কাঠামো
প্রস্তাবিত কাস্টমাইজেশন ওভারলে গঠন নিম্নরূপ:
<path-to-OEM-overlays>/overlay/framework/base/core/res/। বিল্ড-টাইম ওভারলে রিসোর্সrro/Android.mk। এই ফোল্ডারে থাকা সংস্থানগুলির উপর ভিত্তি করে প্রতিটি লক্ষ্য প্যাকেজের জন্য RROs তৈরি করতে মেকফাইল ব্যবহার করা হয়।AndroidManifest.xml। উপরের মেকফাইল দ্বারা ব্যবহৃত একটি ম্যানিফেস্ট ফাইল টেমপ্লেট।res/। সমস্ত টার্গেট অ্যাপে প্রয়োগ করার জন্য রানটাইম ওভারলে।
একক বিল্ড টার্গেটে তারা কতগুলি ব্র্যান্ড পরিচালনা করতে চায় তার উপর নির্ভর করে OEM-এর এই কাঠামোগুলির একটিরও বেশি থাকতে পারে (দেখুন একাধিক ব্র্যান্ড হ্যান্ডেল করুন )।
রানটাইম রিসোর্স ওভারলে
OEM ওভারলে ফোল্ডারের RRO ফোল্ডারে সমস্ত টার্গেট অ্যাপে প্রয়োগ করার জন্য সংস্থান থাকা উচিত। RRO-র যৌগিক সম্পদ ওভারলে করার ক্ষমতাকে প্রভাবিত করার সীমাবদ্ধতা রয়েছে। সংক্ষেপে, একটি RRO:
টার্গেট APK বা RRO-তে সংজ্ঞায়িত রিসোর্স শনাক্তকারীর উল্লেখ করা যাবে না । এর মানে হল যে RROগুলি নতুন শনাক্তকারী যেমন নতুন অঙ্কনযোগ্য, রঙ বা শৈলী যোগ করতে পারে না।
পারে ফ্রেমওয়ার্কের মধ্যে সংজ্ঞায়িত সম্পদ শনাক্তকারীর উল্লেখ করুন, সেই সম্পদগুলিকে
/frameworks/base/core/resবা বিল্ড-টাইম ওভারলে দ্বারা সংজ্ঞায়িত করা হয়েছে কিনা। এই শনাক্তকারীদের অবশ্যইandroid:name-space:সর্বজনীন ডিভাইসডিফল্ট RRO-এর জন্য,
androidব্যবহার করুন।
উদাহরণস্বরূপ,@android:style/TextAppearance.DeviceDefault.Large।অন্য সকলের জন্য (অ-সর্বজনীন বা বিল্ড-টাইম ওভারলে এর মাধ্যমে যোগ করা সংস্থান),
*androidব্যবহার করুন ।
উদাহরণস্বরূপ,@*android/style:TextAppearance.OEM.Brand1.Title।
সম্পদ ছাড়াও, RRO ফোল্ডারে থাকতে হবে:
AndroidManifest.xml। নীচের নমুনায়,RRO_PACKAGE_NAMEএবংTARGET_PACKAGE_NAMEহল মেকফাইলের স্থানধারক:<?xml version=“1.0” encoding=“utf-8”?> <manifest xmlns:android=“http://schemas.android.com/apk/res/android” package=“{{RRO_PACKAGE_NAME}}” /> <application android:hasCode=“false” /> <overlay android:priority=“10” android:targetPackage=“{{TARGET_PACKAGE_NAME}}” android:requiredSystemPropertyName=“ro.product.sku” android:requiredSystemPropertyValue=“<your-product-sku>” /> </manifest>
Android.mkনিম্নলিখিত মেকফাইলেরoemউপসর্গটিকে সংজ্ঞায়িত করে যা সমস্ত জেনারেট করা RRO-তে থাকবে।LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) CAR_UI_RRO_SET_NAME := oem CAR_UI_RESOURCE_DIR := $(LOCAL_PATH)/res CAR_UI_RRO_TARGETS := $(CAR_UI_RRO_PACKAGE_NAMES) include packages/apps/Car/libs/car-ui-lib/generate_rros.mk
RRO কনফিগার করুন
একটি নতুন কনফিগারেশন ফাইল সমর্থিত, overlayable.xml , যা আপনি অ্যাক্সেস নিয়ন্ত্রণ সংজ্ঞায়িত করতে ব্যবহার করতে পারেন। উদাহরণস্বরূপ, আপনি নির্দিষ্ট করতে পারেন কে সংস্থানগুলিকে ওভারলে করতে পারে সেইসাথে কোন সংস্থানগুলিকে ওভারলে করা যেতে পারে৷ ফলস্বরূপ, সংস্থানগুলিকে এখন বিভিন্ন উপায়ে গোষ্ঠীভুক্ত করা যেতে পারে যাতে সেগুলিকে বিভিন্ন RRO দ্বারা ওভারলেড করা যায়।
RRO অ্যাক্সেস নিয়ন্ত্রণ সেট আপ করতে:
-
res/valuesফোল্ডারে,overlayable.xmlতৈরি করুন। -
<overlayable>রিসোর্স ট্যাগ তৈরি করুন। -
<overlayable>ট্যাগের জন্যnameবৈশিষ্ট্যটি সংজ্ঞায়িত করুন, যা প্যাকেজে অনন্য হতে হবে। প্রতিটি ওভারলে শুধুমাত্র একটি ওভারলেযোগ্য গোষ্ঠীকে লক্ষ্য করতে পারে। -
<overlayable>এর ভিতরে<policy>ট্যাগটি সংজ্ঞায়িত করুন। - ওভারলেড করা যেতে পারে এমন সংস্থানগুলির গ্রুপগুলিকে সংজ্ঞায়িত করুন। যেমন:
<resources> <overlayable name="OverlayableResources"> <policy type="public"> <item type="string" name="app_title" /> </policy> </overlayable> </resources>
আপনার RRO প্রকল্পে নিম্নলিখিত পরিবর্তনগুলি প্রয়োগ করতে:
-
res/xmlফোল্ডারে,overlays.xmlতৈরি করুন।overlayজন্য নীচের কোড নমুনা এন্ট্রি দেখুন. - ওভাররাইড করা সম্পদ সংজ্ঞায়িত করুন.
-
AndroidManifest.xmlএ<overlay>ট্যাগেandroid:resourcesMap="@xml/overlays"যোগ করুন। উদাহরণস্বরূপ, নীচের কোড নমুনায়,<overlay>এর জন্য এন্ট্রি দেখুন। - একটি স্ট্যাটিক ওভারলে এর জন্য
android:isStatic=”true”সেট করুন। প্রতিটি ওভারলে ওভারলে করা যেতে পারে এমন গ্রুপগুলির মধ্যে শুধুমাত্র একটিকে লক্ষ্য করতে পারে।
নিম্নলিখিত উদাহরণ বিবেচনা করুন. প্রথম বিভাগটি AndroidManifest.xml এর অন্তর্গত যেখানে দ্বিতীয় বিভাগটি overlays.xml এর সাথে সম্পর্কিত।
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.android.car.ui.rro" android:versionCode="1" android:versionName="1.0"> <overlay android:targetName="OverlayableResources" android:resourcesMap="@xml/overlays" android:targetPackage="com.android.car.ui" android:priority="1" android:isStatic="false" /> </manifest> <overlay> <item target="string/app_title" value="@ string/app_title" /> </overlay>
একটি সতর্কতার সাথে, পূর্বে বিদ্যমান আরআরওগুলি Android 10-এ কাজ করে। সতর্কতা হল প্যাকেজম্যানেজারআরআরও-এর সাথে ইনস্টল করার জন্য, প্যাকেজগুলিকে হয় আগে থেকে ইনস্টল করতে হবে বা লক্ষ্য অ্যাপের মতো একই কী দিয়ে স্বাক্ষর করতে হবে। অ্যান্ড্রয়েড 10-এ, লেআউট ফাইলগুলি ওভারলেড করা যেতে পারে। যাইহোক, এটি করার জন্য findViewById() এর পরিবর্তে ভিউ পাওয়ার সময় requireViewById() ব্যবহার করতে হবে। অ্যান্ড্রয়েড 10-এ, লেআউট ওভারলে সমর্থন করার জন্য এই পরিবর্তনটি car-ui-lib-এ প্রয়োগ করা হয়েছে।
অ্যান্ড্রয়েডের পরবর্তী বড় রিলিজ আপনাকে একটি লেআউট ফাইল ওভারলে করতে এবং RRO প্যাকেজে নতুন সংস্থান সংজ্ঞায়িত করতে এবং অভ্যন্তরীণভাবে তাদের উল্লেখ করতে সক্ষম করবে।
OEM-নির্দিষ্ট সংস্থান যোগ করুন
RRO সীমাবদ্ধতাগুলি কাটিয়ে উঠতে যা OEM সংস্থানগুলিকে যুক্ত হতে বাধা দেয়:
- বিল্ড-টাইম ওভারলে ব্যবহার করে ফ্রেমওয়ার্ক/বেস প্রসারিত করুন, যেকোনো প্রয়োজনীয় সংস্থান যোগ করুন।
-
*android:নেমস্পেসিং ব্যবহার করে OEM RROs থেকে এই সংস্থানগুলি দেখুন।
উদাহরণস্বরূপ, নিম্নলিখিতটি একটি OEM নির্দিষ্ট অঙ্কনযোগ্য যোগ করার এবং এটি একটি RRO-তে ব্যবহার করার একটি উপায়:
<path-to-OEM-overlays>overlay/framework/base/core/res/res/drawable/oem_background_drawable.xml
rro/res/valuesdrawables.xml<resources> <item type="drawable" name="car_ui_toolbar_background"> @*android:drawable/oem_background_drawable </item> </resources>
একাধিক ব্র্যান্ড হ্যান্ডেল
RRO ম্যানিফেস্ট ফাইলগুলির একটি সিনট্যাক্স থাকে যাতে সেগুলিকে সিস্টেমের বৈশিষ্ট্যের উপর ভিত্তি করে শর্তসাপেক্ষে প্রয়োগ করা যায়৷ একটি একক সিস্টেম ইমেজে একাধিক ব্র্যান্ড পরিচালনা করতে, OEMগুলি এটিকে নিম্নরূপ ব্যবহার করতে পারে ( সাধারণ কাঠামো দেখুন)।
<?xml version=“1.0” encoding=“utf-8”?> <manifest xmlns:android=“http://schemas.android.com/apk/res/android” package=“{{RRO_PACKAGE_NAME}}”/> <application android:hasCode=“false”/> <overlay android:priority=“10” android:targetPackage=“{{TARGET_PACKAGE_NAME}}” android:requiredSystemPropertyName=“ro.product.sku” android:requiredSystemPropertyValue=“<your-product-sku>”/> </manifest>
android:requiredSystemPropertyName এবং android:requiredSystemPropertyValue এর জন্য সিনট্যাক্সের কারণে এই RRO সক্রিয় করা হবে শুধুমাত্র যদি সংশ্লিষ্ট সিস্টেম প্রপার্টি প্রদত্ত মানের সাথে মেলে। OEMগুলি তারপরে এই RROগুলির একাধিক সংজ্ঞায়িত করতে পারে, সেগুলির সবগুলিই স্থিতিশীলভাবে সক্ষম এবং একবারে শুধুমাত্র একটি সক্রিয় থাকে৷
একটি লক্ষ্যে কার UI লাইব্রেরি যোগ করুন
একটি Android টার্গেটে Car UI লাইব্রেরি অন্তর্ভুক্ত করতে, আপনাকে অবশ্যই নিম্নলিখিত কোড স্নিপেট অন্তর্ভুক্ত করতে হবে:
# Include build-time overlays PRODUCT_PACKAGE_OVERLAYS += \ <path-to-oem-overlays>/overlay # Define package names to generate RROs for CAR_UI_RRO_PACKAGE_NAMES += \ com.android.car.ui.paintbooth \ com.android.car.media \ com.android.car.dialer \ com.android.car.linkviewer \ com.android.car.settings \ com.android.car.systemupdater \ com.google.android.apps.automotive.inputmethod \ com.google.android.apps.automotive.templates.host \ ... # Include generated RROs PRODUCT_PACKAGES += \ oem-com-android-car-ui-paintbooth \ oem-com-android-car-media \ oem-com-android-car-dialer \ oem-com-android-car-linkviewer \ oem-com-android-car-settings \ oem-com-android-car-systemupdater \ oem-com-google-android-apps-automotive-inputmethod \ oem-com-google-android-apps-automotive-templates-host \ ...
কারণ
<path-to-OEM-overlays>/rro/Android.mkCAR_UI_RRO_PACKAGE_NAMESএ নাম দেওয়া প্রতিটি প্যাকেজের জন্য একটি করে RRO তৈরি করে।PRODUCT_PACKAGESএ জেনারেট করা RROগুলি অন্তর্ভুক্ত করে৷OEM-নির্দিষ্ট সংস্থান যোগ করতে
PRODUCT_PACKAGE_OVERLAYSএ একটি বিল্ড-টাইম ওভারলে অন্তর্ভুক্ত করে৷
কোন প্যাকেজগুলি car-ui-lib সমর্থন করে তা জানতে, car-ui-lib ধারণকারী প্যাকেজগুলির তালিকা দেখুন।