এখন যেহেতু কার 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/values
drawables.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.mk
CAR_UI_RRO_PACKAGE_NAMES
এ নাম দেওয়া প্রতিটি প্যাকেজের জন্য একটি করে RRO তৈরি করে।PRODUCT_PACKAGES
এ জেনারেট করা RROগুলি অন্তর্ভুক্ত করে৷OEM-নির্দিষ্ট সংস্থান যোগ করতে
PRODUCT_PACKAGE_OVERLAYS
এ একটি বিল্ড-টাইম ওভারলে অন্তর্ভুক্ত করে৷
কোন প্যাকেজগুলি car-ui-lib
সমর্থন করে তা জানতে, car-ui-lib ধারণকারী প্যাকেজগুলির তালিকা দেখুন।