গাড়ির সেটিংস ( packages/apps/Car/Settings
) বিশেষভাবে Android Automotive OS (AAOS)-এর জন্য প্রদান করা হয়েছে। গাড়ির সেটিংস ফোন সেটিংস ( packages/apps/Settings
) থেকে আলাদা। গাড়ির সেটিংসে কিছু পরিচিত ফোন সেটিংস থাকলেও, গাড়ির সেটিংস একটি গাড়ি-ফাইড ভিজ্যুয়াল ইউজার ইন্টারফেস, ড্রাইভার ডিস্ট্রাকশন অপ্টিমাইজেশন এবং OEM-এর জন্য অসংখ্য কাস্টমাইজেশন এন্ট্রি পয়েন্ট প্রদান করে।
নীচে দেওয়া গাড়ি সেটিংসের ওভারভিউ ছাড়াও, গাড়ি সেটিংস সম্পর্কে আরও জানতে এই সম্পর্কিত বিষয়গুলি দেখুন:
- গাড়ির সেটিংস যোগ করা হচ্ছে
- গাড়ির সেটিংস পুনর্বিন্যাস করা
- কার সেটিংসে ডিস্ট্রাকশন অপ্টিমাইজেশান
- গাড়ী সেটিংস অনুসন্ধান সূচক
- ডুয়াল প্যান কাস্টমাইজেশন
স্থাপত্য এবং নির্দেশিকা
কার সেটিংসের বেশিরভাগ পৃষ্ঠাগুলি সেটিং ফ্র্যাগমেন্টকে প্রসারিত করে এমন টুকরোগুলির একটি সিরিজ হিসাবে প্রয়োগ করা হয়, যার প্রত্যেকটির নিজস্ব কার্যকলাপ CarSettingActivities- এ সংজ্ঞায়িত করা হয়েছে। এই স্ট্যাটিক কার্যকলাপগুলি BaseCarSettingsActivity থেকে প্রসারিত হয়। যদিও এই নিয়মের কিছু ব্যতিক্রম রয়েছে, যেমন SettingsFragment
এর পরিবর্তে বেসফ্র্যাগমেন্টকে প্রসারিত করে কিছু বিশেষ খণ্ড এবং CarSettingActivities-এর বাইরে থাকা কিছু ক্রিয়াকলাপ, যার সবকটিই ব্যতিক্রম হিসাবে গণ্য করা উচিত (অনুসরণ করার নিদর্শন হিসাবে নয়)।
স্ট্যাটিক পছন্দ
পছন্দ বা CarUiPreference ট্যাগ ব্যবহার করে XML-এ একটি স্ট্যাটিক পছন্দ সংজ্ঞায়িত করা হয়। একটি SettingsFragment
ইমপ্লিমেন্টেশন getPreferenceScreenResId()
পদ্ধতি ব্যবহার করে তা নির্ধারণ করতে যে কোন XML ফাইলে প্রদর্শিত পছন্দের স্ট্যাটিক তালিকা রয়েছে।
গতিশীল পছন্দ
গতিশীল পছন্দগুলি PreferenceGroup ট্যাগ বা PreferenceGroup এর বাস্তবায়ন ব্যবহার করে।
CarSettings অ্যাপের মধ্যে, গতিশীল পছন্দগুলি পছন্দের একটি সাধারণ সেট উপস্থাপন করে যা ব্যবহারকারীকে CarSettings-এর মধ্যে অতিরিক্ত পৃষ্ঠাগুলিতে নির্দেশ করে, কিন্তু যেগুলি XML-এর পরিবর্তে পছন্দ কন্ট্রোলারের মাধ্যমে যোগ করা হয়েছে। একটি উদাহরণ হল ভাষা এবং ইনপুট পছন্দের অধীনে কীবোর্ড পছন্দ পরিচালনা করুন যা এই ইনপুট পদ্ধতিগুলি অনুমোদিত কি না তার উপর ভিত্তি করে অগ্রাধিকার পৃষ্ঠায় গতিশীলভাবে ইনপুট পদ্ধতি যুক্ত করে।
অ্যাকশন বার
প্রতিটি সেটিংস স্ক্রিনের শীর্ষে একটি অ্যাকশন বার রয়েছে, যাতে একটি "ব্যাক" নেভিগেশন, একটি স্ক্রিন শিরোনাম এবং সম্পূরক অ্যাকশন উইজেট (উদাহরণস্বরূপ, বোতাম এবং সুইচ) থাকতে পারে। এই অ্যাকশন বারগুলি অ্যান্ড্রয়েড দ্বারা প্রদত্ত অ্যাকশনবারের মতো, কিন্তু আসলে কাস্টম ভিউ। অ্যান্ড্রয়েড 11 এবং তার উপরে, এই টুলবারটি চ্যাসিস বেস লেআউটে অন্তর্ভুক্ত করা হয়েছে, যেটিতে টুলবারের ভিউ এবং অ্যাপের বাকি কন্টেন্টের জন্য একটি ফ্রেমলেআউট রয়েছে।
পরিপূরক অ্যাকশন উইজেটগুলি হল MenuItem ক্লাস এবং সংশ্লিষ্ট SettingsFragment
বা BaseFragment
এর onCreate
এ তৈরি করা উচিত। বৈশিষ্ট্য যেমন দৃশ্যমানতা, অবস্থা, এবং তাই SettingsFragment
এর ব্যবসায়িক যুক্তিতে সেটারের দ্বারা নিয়ন্ত্রিত হওয়া উচিত।
// ExampleSettingsFragment.java
public class ExampleSettingsFragment extends SettingsFragment {
@Override
protected List<MenuItem> getToolbarMenuItems() {
return Collections.singletonList(mClearConfirmButton);
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mButton = new MenuItem.Builder(getContext())
.setTitle(R.string.text)
.setOnClickListener(mOnClickListener)
.setUxRestrictions(CarUxRestrictions.UX_RESTRICTIONS_NO_SETUP)
.build();
}
private void updateState() {
button.setVisible(false);
}
}
অ্যাকশন বারগুলি গাড়ি সেটিংসে ডিস্ট্রাকশন অপ্টিমাইজেশানের জন্য সমর্থন সহ আসে৷ তৈরিতে MenuItem.Builder
এ UXRestrictions সেট করুন।
পছন্দ কন্ট্রোলার
প্রতিটি সেটিংস পৃষ্ঠায় বিভিন্ন পছন্দের সংখ্যা থাকতে পারে।
এই উপাদানগুলি কীভাবে সম্পর্কিত তার জন্য নিম্নলিখিত চিত্রটি দেখুন:
চিত্র 1. কারসেটিংস উপাদান
PreferenceController
হল একটি জীবনচক্র-সচেতন উপাদান যা নির্দিষ্ট পছন্দগুলির সাথে সম্পর্কিত ব্যবসায়িক যুক্তিকে এনক্যাপসুলেট করতে সাহায্য করে। PreferenceControllers
শুধুমাত্র XML এর মাধ্যমে প্রাসঙ্গিক পছন্দের সাথে সংযুক্ত করা যেতে পারে।
// example_settings_fragment.xml
<PreferenceScreen
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:settings="http://schemas.android.com/apk/res-auto"
android:title="@string/example_settings_title">
<Preference
android:key="@string/pk_example_preference_key"
android:title="@string/example_preference_title"
settings:controller="com.android.car.settings.example.ExamplePreferenceController"/>
</PreferenceScreen>
গাড়ির সেটিংস স্পষ্টভাবে কোডের মাধ্যমে PreferenceController
তৈরিতে বাধা দেয় যাতে জাভা কোডে ন্যূনতম পরিবর্তনের সাথে সেটিংসের শ্রেণিবিন্যাস পরিবর্তন করা সহজ হয়।
এটা সম্ভব যে একটি PreferenceController
সঠিকভাবে কাজ করার জন্য কিছু গতিশীল ডেটার প্রয়োজন। উদাহরণস্বরূপ, একটি PreferenceController
যেটি একটি অ্যাপের জন্য বিজ্ঞপ্তিগুলি বন্ধ করে দেয় তা জানতে হবে কোন অ্যাপটিতে কাজ করতে হবে। যেহেতু PreferenceControllers
সবসময় XML-এ সংজ্ঞায়িত করা হয়, অতিরিক্ত কনস্ট্রাক্টর আর্গুমেন্ট দেওয়ার কোন উপায় নেই। পরিবর্তে, এই অতিরিক্ত মানগুলি PreferenceController
এ পাবলিক সেটারের মাধ্যমে প্রদান করা হয় এবং SettingsFragment
থেকে use(...)
পদ্ধতি ব্যবহার করে সেট করা হয়।
// ExamplePreferenceController.java
public class ExamplePreferenceContorller extends PreferenceController<Preference> {
private ExampleArg mExampleArg;
public ExamplePreferenceController(...) {
...
}
public void setExampleArg(ExampleArg exampleArg) {
mExampleArg = exampleArg;
}
}
// ExampleSettingsFragment.java
public class ExampleSettingsFragment extends SettingsFragment {
@Override
@XmlRes
protected int getPreferenceScreenResId() {
Return R.xml.example_settings_fragment;
}
@Override
public void onAttach(Context context) {
ExampleArg arg = (ExampleArg) getArguments().getSerializeable(ARG_KEY);
ExamplePreferenceController controller =
use(ExamplePreferenceController.class, R.string.pk_example_preference_key);
controller.setExampleArg(arg);
}
}
যত বেশি use(...)
পদ্ধতি ব্যবহার করা হয়, জাভা কোডে ন্যূনতম পরিবর্তনের সাথে সেটিংসের শ্রেণিবিন্যাস পুনর্বিন্যাস করতে সক্ষম হওয়ার মূল লক্ষ্য রাখা তত কঠিন হয়ে ওঠে, কারণ বিদ্যমান ফ্র্যাগমেন্ট কোডের বড় অংশগুলি সদ্য নির্মিত খণ্ডে অনুলিপি করা হয়েছে। এটি করার অসুবিধা কমানোর একটি উপায় হল:
- আপনার
use(...)
। - প্রতিটি কল
use(...)
খণ্ডের এক জায়গায় রাখার চেষ্টা করুন (উদাহরণস্বরূপ,onAttach()
পদ্ধতিতে)।
অভিপ্রায় হ্যান্ডলিং
গাড়ি সেটিংস অ্যাপের দ্বারা পরিচালনা করা উচিত এমন সমস্ত উদ্দেশ্যগুলি ম্যানিফেস্ট ফাইলে সংজ্ঞায়িত করা হয়েছে৷ মেনিফেস্টে সংজ্ঞায়িত সমস্ত ক্রিয়াকলাপ এবং অভিপ্রায় ফিল্টার সহ, ইন্টেন্টগুলি সাধারণত বেশিরভাগ স্ট্যান্ডার্ড অ্যান্ড্রয়েড অ্যাপের মতো সংজ্ঞায়িত এবং পরিচালনা করা হয়।
মূল টুকরা পরিবর্তন করুন
যদি ইচ্ছা হয়, config_show_settings_root_exit_icon
ব্যবহার করে প্রস্থান আইকন প্রদর্শিত বা লুকানো যেতে পারে।
থিম কাস্টমাইজ করুন
অন্যান্য বৈশিষ্ট্য এবং সম্পদ কাস্টমাইজ করুন
কার সেটিংস অ্যাপটি প্রাথমিকভাবে CarSettingTheme
ব্যবহার করে, যা Theme.CarUi
এর একটি এক্সটেনশন। এই থিমটি সিস্টেমে সামঞ্জস্যতা নিশ্চিত করতে সিস্টেম অ্যাপগুলির চেহারা এবং অনুভূতি মানক করতে ব্যবহৃত হয়৷
পছন্দগুলি কাস্টমাইজ করুন
কাস্টমাইজ করা পছন্দগুলি এই অতিরিক্ত অবস্থানগুলিকে বিস্তৃত করে:
- কিছু বেস প্রেফারেন্স ক্লাসের লেআউট
car_preference
এ সংজ্ঞায়িত করা হয় এবং গাড়ি তৈরির জন্য ওভারলেড করা হয় । বেস প্রেফারেন্স ক্লাসের জন্য যেকোনো কাস্টমাইজেশন লেআউট এখানে প্রতিস্থাপন করা যেতে পারে। - গাড়ির সেটিংস প্রাথমিকভাবে
common
প্যাকেজে সংজ্ঞায়িত কিছু কাস্টম পছন্দ ব্যবহার করে। বেস প্রেফারেন্স ক্লাস থেকে আলাদাভাবে কার সেটিংস মডিউলের মধ্যে এগুলি ওভারলেড করা উচিত।