मीडिया को पसंद के मुताबिक बनाएं

मीडिया, सिस्टम ऐप्लिकेशन के सुइट से जुड़ा हो. उदाहरण के लिए, डायलर और ऐप्लिकेशन लॉन्चर. ये ऐप्लिकेशन, AOSP के स्ट्रक्चर में अलग-अलग लेवल पर तय किए गए सामान्य स्टाइल और एसेट शेयर करते हैं.

  • framework/base. Android के सभी बेस स्टाइल यहां बताए गए हैं.
  • packages/services/Car/car_product/overlay. इसमें बिल्ड टाइम ओवरले शामिल होते हैं, जो Android Automotive OS के AOSP लुक-एंड-फ़ील को बनाने के लिए, स्टैंडर्ड फ़्रेमवर्क/बेस संसाधनों में बदलाव करते हैं. OEM, इस ओवरले को हटाकर अपने ओवरले का इस्तेमाल कर सकते हैं.
  • packages/apps/Car/libs/car-ui-lib. इस लाइब्रेरी में, AAOS के कॉम्पोनेंट और संसाधनों के बारे में बताया गया है. ये कॉम्पोनेंट और संसाधन, सिस्टम ऐप्लिकेशन और उन ऐप्लिकेशन के लिए सामान्य होते हैं जिन्हें उपयोगकर्ता के हिसाब से बनाने के लिए डिज़ाइन किया गया है. ज़्यादा जानकारी के लिए, कार यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी इंटिग्रेशन गाइड देखें.
  • packages/apps/Car/libs/car_app_common. Automotive सिस्टम के ऐप्लिकेशन के बीच शेयर किए जाने वाले सामान्य रंग और स्टाइल. इन एलिमेंट को पसंद के मुताबिक बनाने के लिए, OEM ओवरले का इस्तेमाल कर सकते हैं. ये ऊपर बताए गए car_product/overlay से मिलते-जुलते हैं.
  • packages/apps/Car/libs/car_media_common. इसमें मीडिया और अन्य मीडिया यूज़र इंटरफ़ेस (यूआई) के बीच शेयर किए गए एलिमेंट होते हैं. उदाहरण के लिए, होम स्क्रीन मीडिया विजेट.
  • packages/apps/Car/Media. सभी सिस्टम ऐप्लिकेशन अपनी थीम का इस्तेमाल करते हैं. यह थीम, car-ui-lib में बताई गई Theme.CarUi से शुरू होती है.

Android Automotive AOSP, मीडिया के दो प्रज़ेंटेशन उपलब्ध कराता है.

  • मीडिया का यूज़र इंटरफ़ेस (यूआई). इससे उपयोगकर्ताओं को साइन इन करने, कॉन्टेंट ब्राउज़ करने, और वीडियो चलाने के लिए बेहतर कंट्रोल इस्तेमाल करने की सुविधा मिलती है.
  • होम स्क्रीन पर मीडिया विजेट. होम स्क्रीन पर, मीडिया चलाने के मुख्य कंट्रोल की सुविधाओं का इस्तेमाल करने की अनुमति देता है.

मीडिया का यूज़र इंटरफ़ेस

इस इमेज में, मीडिया यूज़र इंटरफ़ेस (यूआई) के स्ट्रक्चर के बारे में बताया गया है:

मीडिया का यूज़र इंटरफ़ेस (यूआई)

पहली इमेज. मीडिया का यूज़र इंटरफ़ेस.

यूज़र एक्सपीरियंस (यूएक्स) और यूज़र इंटरफ़ेस (यूआई) के दिशा-निर्देशों के साथ-साथ मीडिया के अलग-अलग कॉम्पोनेंट के स्पेस के स्ट्रक्चर के बारे में जानकारी पाने के लिए, स्पेशल मॉडल देखें.

AppBarView: टूलबार

मीडिया यूज़र इंटरफ़ेस (यूआई) टूलबार, सिस्टम के अन्य ऐप्लिकेशन के साथ शेयर किया जाने वाला कॉम्पोनेंट है. जैसे, डायलर और रेडियो. टूलबार को पसंद के मुताबिक बनाने का तरीका जानने के लिए, कार यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी इंटिग्रेशन गाइड देखें.

मीडिया के लिए आर्टवर्क का ज़्यादा से ज़्यादा साइज़

मीडिया ऐप्लिकेशन को, फ़ेच किए जाने वाले आर्टवर्क के ज़्यादा से ज़्यादा साइज़ की सूचना देने के लिए, अपने सिस्टम में media_items_bitmap_max_size_px को ओवरले किया जा सकता है. ऐसा करने के लिए, रूट हिंट के तौर पर EXTRA_MEDIA_ART_SIZE_HINT_PIXELS भेजें. इस वजह से, इमेज डाउनलोड करते समय बैंडविड्थ की बचत होगी. ज़्यादा जानने के लिए, developer.android.com पर MediaConstants देखें.

फ़्रैगमेंट ब्राउज़ करें

ब्राउज़ करने की सुविधा में मुख्य रूप से कार के यूज़र इंटरफ़ेस का RecyclerView होता है. यह स्क्रोलबार की पोज़िशन, ऐरो, और मार्जिन को मैनेज करता है. साथ ही, अलग-अलग तरह के आइटम ब्राउज़ कर सकता है. जैसे, हेडर, ग्रिड आइटम, आइकॉन ग्रिड आइटम, लिस्ट आइटम, और आइकॉन लिस्ट आइटम.

छोटे किए गए प्लेबैक कंट्रोल

ब्राउज़ फ़्रैगमेंट दिखने और कोई मीडिया आइटम चुनने पर, कम किए गए प्लेबैक कंट्रोल व्यू दिखता है. इस विज़ुअल में, इस व्यू का स्ट्रक्चर दिखाया गया है:

छोटे किए गए प्लेबैक कंट्रोल

दूसरी इमेज. छोटे किए गए प्लेबैक कंट्रोल.

सूची ब्राउज़ करें

डेवलपर, मीडिया ब्राउज़ करने के लिए उपलब्ध कॉन्टेंट के प्रज़ेंटेशन को पसंद के मुताबिक बनाने के लिए, स्टाइल हिंट के सेट का इस्तेमाल कर सकते हैं. इसके लिए, कॉन्टेंट स्टाइल लागू करें देखें. OEM को अपने डिज़ाइन सिस्टम के हिसाब से प्रज़ेंटेशन को अडजस्ट करते हुए, इन स्टाइल का पालन करना होगा.

इस्तेमाल किए जा सकने वाले आइटम टाइप और उनके लेआउट यहां दिए गए हैं:

  • LIST_ITEM (media_browse_list_item.xml). आम तौर पर, पॉडकास्ट के एपिसोड के लिए इस्तेमाल किया जाता है. जैसे, प्लेलिस्ट आइटम और पसंदीदा आइटम.
  • ICON_LIST_ITEM (media_browse_list_icons_item.xml). इसका इस्तेमाल कैटगरी या मेन्यू के विकल्पों के लिए किया जाता है. इसमें मीडिया आइटम के साथ शामिल इमेज, एल्बम आर्ट के बजाय एक आइकॉन है.
  • GRID_ITEM (media_browse_grid_item.xml). आम तौर पर, इसे गाना या प्लेलिस्ट जैसे चलाए जा सकने वाले आइटम के लिए इस्तेमाल किया जाता है.
  • ICON_GRID_ITEM (media_browse_grid_icons_item.xml). ICON_LIST_ITEM की तरह ही, कैटगरी के लिए इस्तेमाल किया जाता है.
  • HEADER (media_browse_header_item.xml). इसका इस्तेमाल, मीडिया आइटम को सेक्शन में व्यवस्थित करने के लिए किया जाता है.

प्लेबैक स्क्रीन

यह स्क्रीन देखने के लिए, छोटे किए गए प्लेबैक कंट्रोल को बड़ा करें:

  • फ़िलहाल चल रहे मीडिया आइटम का मेटाडेटा. इसमें टाइटल और सबटाइटल शामिल हैं.
  • प्लेबैक कंट्रोल पूरे करें.
  • वीडियो चलाने की सूची (हाल ही में चलाए गए या आगे चलने वाले आइटम दिखाने के लिए इस्तेमाल किया जाता है).

प्लेबैक स्क्रीन के कॉम्पोनेंट की पहचान, नीचे दिए गए इलस्ट्रेशन में की गई है.

प्लेबैक स्क्रीन

तीसरा चित्र. प्लेबैक स्क्रीन.

'प्लेबैक' स्क्रीन, टूलबार को ऐप्लिकेशन के बाकी हिस्सों के साथ शेयर नहीं करती. इसके बजाय, यह स्क्रीन, स्क्रीन पर सबसे ऊपर मौजूद एलिमेंट को अलग-अलग मैनेज करती है.

ऑडियो फ़ॉर्मैटिंग एट्रिब्यूशन

जब ऐप्लिकेशन, फ़िलहाल चल रहे मीडिया आइटम के एक्सट्रा में KEY_CONTENT_FORMAT_TINTABLE_LARGE_ICON_URI या KEY_CONTENT_FORMAT_TINTABLE_SMALL_ICON_URI सेट करते हैं. OEM को यूआरआई के मुताबिक, सही वेक्टर ड्रॉबल रेंडर करना होगा.

मुख्य वीडियो चलाने के व्यू में, कॉन्टेंट फ़ॉर्मैट आइकॉन के बड़े वर्शन का इस्तेमाल करना ज़रूरी है. OEM, छोटे व्यू पर कॉन्टेंट फ़ॉर्मैट आइकॉन के छोटे वर्शन का इस्तेमाल कर सकते हैं. जैसे, छोटा प्लेलिस्ट बार. ContentFormatView, अपने logoSize एट्रिब्यूट के आधार पर सबसे अच्छा आइकॉन रेंडर करता है.

जब ऐप्लिकेशन KEY_SUBTITLE_LINK_MEDIA_ID या KEY_DESCRIPTION_LINK_MEDIA_ID सेट करते हैं, तो OEM को सबटाइटल या ब्यौरे को इस तरह रेंडर करना चाहिए कि उन पर टैप किया जा सके. इसके बाद, उपयोगकर्ता के टैप करने पर लिंक किया गया मीडिया आइटम दिखाने के लिए, ब्राउज़ व्यू खोलें.

प्लेबैक कंट्रोल

प्लेबैक स्क्रीन में, प्लेबैक कंट्रोल का बड़ा सेट शामिल होता है. इसे कंट्रोल पंक्तियों में व्यवस्थित किया जाता है. सेकंडरी लाइन (यह सबसे ऊपर वाली लाइन के तौर पर नीचे दिखती है) सिर्फ़ तब दिखती है, जब PlaybackStateCompat#getActions() से मीडिया ऐप्लिकेशन की ओर से दी गई सभी कार्रवाइयों को दिखाने के लिए, पहली लाइन में जगह काफ़ी न हो.

प्लेबैक कंट्रोल

चौथी इमेज. वीडियो चलाने के कंट्रोल.

OEM, स्टैंडर्ड ऐक्शन के आइकॉन को पसंद के मुताबिक बना सकते हैं. हालांकि, उन्हें कस्टम ऐक्शन के आइकॉन को वैसे ही दिखाना होगा जैसे मीडिया ऐप्लिकेशन से मिलते हैं.

होम स्क्रीन पर मौजूद मीडिया विजेट

इस विजेट को car-media-common में फ़्रैगमेंट के तौर पर लागू किया गया है. इस फ़्रैगमेंट में, ऊपर बताई गई प्लेबैक स्क्रीन का छोटा वर्शन शामिल है. कस्टमाइज़ेशन के सभी नियम और सुविधाएं लागू होती हैं.

होम स्क्रीन पर मौजूद मीडिया विजेट

पांचवी इमेज. होम स्क्रीन पर मीडिया विजेट.

ऊपर दिखाया गया ऐप्लिकेशन सिलेक्टर बटन, मीडिया सोर्स स्विच करने के यूज़र फ़्लो में बताई गई स्विच सुविधा का इस्तेमाल करता है.

ऐप्लिकेशन सिलेक्टर बटन के मौजूदा मीडिया सोर्स आइकॉन का इस्तेमाल करने के लिए, platform/packages/apps/Car/libs/car-media-common/res/values/bools.xml में तय किए गए use_media_source_logo_for_app_selector फ़्लैग को ओवरले करें और true पर सेट करें. इस बदलाव के बाद, ऐप्लिकेशन टूलबार के दूसरी तरफ़ मौजूद मीडिया सोर्स आइकॉन को छिपा दिया जाएगा. यह कस्टमाइज़ेशन मीडिया सेंटर ऐप्लिकेशन और पहचान रेडियो ऐप्लिकेशन पर भी लागू होता है.

मीडिया ऐप्लिकेशन चुनने का बटन

छठी इमेज. मीडिया ऐप्लिकेशन चुनने के लिए बटन.

चलाएं, रोकें, और बंद करें बटन का लेआउट

"अभी चल रहा है" और प्लेबैक कंट्रोल के छोटे किए गए व्यू के लिए, चलाएं/रोकें/बंद करें बटन के लेआउट को पसंद के मुताबिक बनाया जा सकता है. दोनों लेआउट, packages/apps/Car/libs/car-media-common/res/layout/ में तय किए गए हैं.

बटन के लेआउट को पसंद के मुताबिक बनाने के लिए, play_pause_stop_button_layout.xml और minimized_play_pause_stop_button_layout.xml पर बिल्ड टाइम ओवरले लागू करें.

प्लेलिस्ट में मौजूद मौजूदा आइटम को हाइलाइट करना

मौजूदा प्लेलिस्ट आइटम की स्थिति selected पर सेट होती है. इसलिए, इसे अपनी पसंद के मुताबिक बनाया जा सकता है. इसके लिए, स्टेटस रिसॉर्स का इस्तेमाल करें. जैसे, कलर स्टेटस की सूचियां (कलर स्टेटस की सूची का रिसॉर्स देखें ) और स्टेटस की सूची के ड्रॉअरबल (ड्रॉअरबल रिसॉर्स देखें). स्टाइल में ज़रूरी बदलाव लागू करने के लिए, सूची में मौजूद आइटम के लेआउट को बदला जा सकता है. इसके लिए, packages/apps/Car/Media/res/layout/queue_list_item.xml या

प्लेलिस्ट में मौजूद मौजूदा आइटम के बगल में भी आइकॉन दिखाया जा सकता है:

  • packages/apps/Car/Media/res/layout/queue_list_item.xml या किसी अलगshow_icon_for_now_playing_queue_list_item

    चलाने का टाइमर छिपाने के लिए, show_time_for_now_playing_queue_list_item को false पर सेट करें.

  • ड्रॉ करने लायक स्थिति का इस्तेमाल करें, जैसे कि आइटम के रूट व्यू के फ़ोरग्राउंड या बैकग्राउंड ( packages/apps/Car/Media/res/layout/queue_list_item.xml या आइटम के व्यू हैरारकी (व्यू और व्यू ग्रुप के लेआउट का क्रम) में कोई अलग व्यू देखें.

सातवीं इमेज. वीडियो चलाने की सूची में मौजूदा आइटम को हाइलाइट किया गया.