कार की सेटिंग (packages/apps/Car/Settings
), खास तौर पर
Android Automotive OS (AAOS). कार की सेटिंग, फ़ोन की सेटिंग से अलग होती हैं
(packages/apps/Settings
). कार की सेटिंग में फ़ोन की कुछ जानी-पहचानी सेटिंग होती हैं,
कार की सेटिंग में, कार-फ़ाई वाला विज़ुअल यूज़र इंटरफ़ेस, ड्राइवर का ध्यान भटकने से रोकने के लिए ऑप्टिमाइज़ेशन,
और OEM के लिए कई कस्टमाइज़ेशन एंट्री पॉइंट मौजूद हैं.
नीचे दी गई कार की सेटिंग की खास जानकारी के अलावा, इनसे जुड़ी अन्य जानकारी भी देखें कार की सेटिंग के बारे में ज़्यादा जानने के लिए विषय:
- कार की सेटिंग जोड़ना
- रिरियर कार की सेटिंग
- कार की सेटिंग में डिस्ट्रैक्शन ऑप्टिमाइज़ेशन
- कार की सेटिंग को खोज के नतीजों में दिखाना
- ड्यूअल पैनल को पसंद के मुताबिक बनाना
आर्किटेक्चर और दिशा-निर्देश
कार की सेटिंग में ज़्यादातर पेज, फ़्रैगमेंट की सीरीज़ के तौर पर लागू किए जाते हैं
जो Settingsफ़्रैगमेंट को बढ़ाती है, जिसमें हर एक की अपनी गतिविधि तय होती है
CarSettingsActivity. इन स्टैटिक गतिविधियों को BaseCarSettingsActivity से बढ़ाया जाता है. हालांकि इस नियम के कुछ अपवाद हैं, जैसे कि कुछ खास फ़्रैगमेंट
SettingsFragment
के बजाय Baseफ़्रैगमेंट और CarSettingsActive के बाहर की कुछ गतिविधियां हैं जिन्हें अपवाद माना जाना चाहिए (फ़ॉलो किए जाने वाले पैटर्न के तौर पर नहीं).
स्टैटिक प्राथमिकताएं
एक्सएमएल में Preference का इस्तेमाल करके, स्टैटिक प्रायॉरिटी तय की जाती है
या CarUiPreference
टैग के साथ जोड़ा जा सकता है. SettingsFragment
को लागू करने के लिए, getPreferenceScreenResId()
का इस्तेमाल किया जाता है
तरीका है, ताकि यह तय किया जा सके कि किस एक्सएमएल फ़ाइल में, दिखाई जाने वाली प्राथमिकताओं की स्टैटिक सूची है.
डाइनैमिक प्राथमिकताएं
डाइनैमिक प्राथमिकताएं, PreferenceGroup का इस्तेमाल करती हैं टैग का इस्तेमाल करके या PreferenceGroup को लागू करना.
CarSettings ऐप्लिकेशन में, डाइनैमिक प्राथमिकताएं, ऐसी प्राथमिकताएं जो लोगों को CarSettings में अन्य पेजों पर ले जाती हैं, जिन्हें Preference के ज़रिए जोड़ा गया है कंट्रोलर के तौर पर उपलब्ध हो. उदाहरण के लिए, कीबोर्ड मैनेज करें भाषाएं और के अंतर्गत प्राथमिकता ऐसी इनपुट प्राथमिकता जो डाइनैमिक तरीके से इनपुट जोड़ती है प्राथमिकता पेज के लिए मैन्युअल तरीके का इस्तेमाल करें. यह इस बात पर निर्भर करता है कि क्या इनपुट के ये तरीके अनुमति है या नहीं.
ऐक्शन बार
हर सेटिंग स्क्रीन के सबसे ऊपर एक कार्रवाई बार होता है, जिसमें "वापस जाएं" और पूरक ऐक्शन विजेट, जैसे कि बटन और स्विच). ये ऐक्शन बार, ActionBar जैसे ही हैं Android से मिले हैं, लेकिन असल में ये कस्टम व्यू हैं. Android 11 और उसके बाद के वर्शन में चेसिस बेस लेआउट में टूलबार शामिल होता है, जिसमें टूलबार और ऐप्लिकेशन के बाकी कॉन्टेंट के लिए फ़्रेम लेआउट.
पूरक ऐक्शन विजेट, मेन्यूItem क्लास हैं और इन्हें इसमें बनाया जाना चाहिए
SettingsFragment
का onCreate
या
BaseFragment
. विज़िबिलिटी, स्थिति वगैरह जैसी प्रॉपर्टी को
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
में, 'उपयोगकर्ता अनुभव से जुड़ी पाबंदियां' सेट करें.
प्राथमिकता कंट्रोलर
हर सेटिंग पेज में कई प्राथमिकताएं.
ये कॉम्पोनेंट आपस में कैसे जुड़े हैं, यह जानने के लिए नीचे दी गई इमेज देखें:
पहली इमेज. कार सेटिंग कॉम्पोनेंट
PreferenceController
, लाइफ़साइकल के बारे में जानकारी देने वाला कॉम्पोनेंट है, जो
खास प्राथमिकताओं से जुड़े कारोबारी लॉजिक को शामिल करें.
PreferenceControllers
को सिर्फ़ सही प्राथमिकता के साथ अटैच किया जा सकता है
एक्सएमएल.
// 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
को बनाने से रोकती हैं
ताकि सेटिंग की हैरारकी में कम से कम
Java कोड में बदलाव करता है.
ऐसा हो सकता है कि PreferenceController
को डाइनैमिक डेटा की ज़रूरत हो
ताकि सही तरीके से काम किया जा सके. उदाहरण के लिए, एक PreferenceController
जो बंद हो जाता है
किसी ऐप्लिकेशन की सूचनाओं के लिए यह जानना ज़रूरी है कि किस ऐप्लिकेशन पर कार्रवाई करनी है.
एक्सएमएल में हमेशा PreferenceControllers
तय होता है, इसलिए यहां कोई
का इस्तेमाल करने का तरीका बताएंगे. इसके बजाय, ये अतिरिक्त वैल्यू
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()
तरीके में).
इंटेंट हैंडलिंग
सभी मकसद जिन्हें कार की सेटिंग ऐप्लिकेशन से मैनेज किया जाना चाहिए उनके बारे में यहां बताया गया है: मेनिफ़ेस्ट फ़ाइल से लिए जाते हैं. इंटेंट को आम तौर पर, ज़्यादातर स्टैंडर्ड Android ऐप्लिकेशन की तरह तय किया जाता है और मैनेज किया जाता है. मेनिफ़ेस्ट में तय की गई सभी गतिविधियों और इंटेंट फ़िल्टर के साथ.
रूट फ़्रैगमेंट बदलें
अगर आप चाहें, तो config_show_settings_root_exit_icon
का इस्तेमाल करके, बाहर निकलें आइकॉन को दिखाया या छिपाया जा सकता है.
थीम को पसंद के मुताबिक बनाना
अन्य एट्रिब्यूट और संसाधनों को पसंद के मुताबिक बनाएं
कार की सेटिंग ऐप्लिकेशन में मुख्य तौर पर, CarSettingTheme
,
जो Theme.CarUi
का एक्सटेंशन है. इस थीम का इस्तेमाल
सिस्टम ऐप्लिकेशन का रंग-रूप दिखाना, ताकि सिस्टम को एक जैसा बनाया जा सके.
प्राथमिकताएं कस्टमाइज़ करें
प्राथमिकताएं कस्टमाइज़ करना इन अतिरिक्त जगहों तक फैला होता है:
- कुछ बुनियादी प्राथमिकता क्लास का लेआउट
car_preference
में बताया गया है और ओवरला किया गया बनाने के लिए डिज़ाइन किया गया है. बेस प्राथमिकता क्लास के लिए कोई भी पसंद के मुताबिक लेआउट यहां बदला गया. - कार की सेटिंग
common
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है पैकेज. इन्हें कार सेटिंग मॉड्यूल के अंदर अलग से लगाया जाना चाहिए बेस प्राथमिकता वाली क्लास.