वैरिएंट, किसी पैनल की खास विज़ुअल स्थिति को तय करता है. इससे एक पैनल को अलग-अलग विज़ुअल फ़ॉर्मैट में दिखाया जा सकता है. जैसे, खुला या बंद स्थिति. वैरिएंट को कॉन्फ़िगर करने के लिए, एक्सएमएल का इस्तेमाल करें. <Panel>
एलिमेंट में सब-टैग का इस्तेमाल करें.
हर <Variant>
टैग में id
एट्रिब्यूट होना ज़रूरी है, ताकि उसकी यूनीक पहचान की जा सके.
टैग, प्रॉपर्टी इनहेरिट करने के लिए पैरंट वैरिएंट का रेफ़रंस भी दे सकता है. इनहेरिटेंस के इस तरीके से, एक से ज़्यादा वैरिएंट में सामान्य प्रॉपर्टी को बेहतर तरीके से तय किया जा सकता है.
एक्सएमएल एट्रिब्यूट
स्टेट और ट्रांज़िशन तय करने के लिए, इन एट्रिब्यूट का इस्तेमाल <TaskPanel>
या <DecorPanel>
टैग के साथ करें.
एट्रिब्यूट | स्थिति | ब्यौरा |
---|---|---|
id |
ज़रूरी है | वैरिएंट का यूनीक आइडेंटिफ़ायर. इस आईडी का इस्तेमाल, ट्रांज़िशन में वैरिएंट को रेफ़र करने के लिए किया जाता है. इसके अलावा, इसे पैनल के लिए defaultVariant के तौर पर भी इस्तेमाल किया जाता है.
|
parent |
वैकल्पिक | इस एट्रिब्यूट का इस्तेमाल करके, किसी दूसरे वैरिएंट का आईडी तय किया जाता है. मौजूदा वैरिएंट को इसी वैरिएंट से प्रॉपर्टी इनहेरिट करनी चाहिए. अगर किसी प्रॉपर्टी को मौजूदा वैरिएंट में साफ़ तौर पर तय नहीं किया गया है, तो वह अपने पैरंट वैरिएंट में तय की गई वैल्यू पर वापस आ जाती है. |
एक्सएमएल चाइल्ड एलिमेंट
इन ज़रूरी नहीं एलिमेंट का इस्तेमाल करके, पैनल की विज़ुअल विशेषताओं के बारे में बताएं. ऐसा तब करें, जब पैनल इस वैरिएंट की स्थिति में हो.
चाइल्ड एलिमेंट | ब्यौरा |
---|---|
<Visibility> |
इससे पता चलता है कि पैनल दिख रहा है या छिपा हुआ है. इसमें isVisible एट्रिब्यूट (बूलियन) होता है. |
<Alpha> |
यह पैनल के पारदर्शिता लेवल के बारे में बताता है. इसमें alpha एट्रिब्यूट (फ़्लोट, 0.0 से 1.0) होता है. |
<Layer> |
यह पैनल के Z-ऑर्डर को अन्य पैनल के हिसाब से सेट करता है. इसमें layer एट्रिब्यूट (पूर्णांक) होता है. ज़्यादा वैल्यू को सबसे ऊपर दिखाया जाता है. |
<Focus> |
इससे यह तय होता है कि ट्रांज़िशन के दौरान पैनल पर फ़ोकस किया जा सकता है या नहीं. इसमें onTransition एट्रिब्यूट (बूलियन) होता है.
|
<Bounds> |
यह स्क्रीन पर पैनल के आयताकार क्षेत्र (जगह और साइज़) को तय करता है. इस एरिया को बाएं, ऊपर, नीचे, चौड़ाई, और ऊंचाई जैसे एट्रिब्यूट से कंट्रोल किया जाता है.
प्रतिशत का इस्तेमाल करते समय, ऑफ़सेट एट्रिब्यूट का इस्तेमाल करके, प्रतिशत के आधार पर तय की गई सीमाओं में बदलाव किया जा सकता है. जैसे, उदाहरण के लिए, अगर आपको यह तय करना है कि कोई पैनल, स्क्रीन की पूरी ऊंचाई में दिखे और बॉटम में मौजूद तय ऊंचाई वाला नेविगेशन बार न दिखे, तो ऊंचाई को 100% पर सेट करें. साथ ही, |
<SafeBounds> |
यह पैनल की सीमाओं के अंदर एक सुरक्षित जगह तय करता है. यह जगह, डिसप्ले कटआउट या इनसेट से ओवरलैप नहीं होती है. इससे यह पता चलता है कि इस जगह पर बनाए गए ऐप्लिकेशन, पैनल के साथ काम करते हैं. इसके एट्रिब्यूट, <Bounds> से मिलते-जुलते हैं.
|
<Corner> |
यह पैनल के कोनों के लिए रेडियस तय करता है. इससे कोनों को गोल किया जा सकता है. इसमें रेडियस एट्रिब्यूट (पूर्णांक) होता है. शार्प कॉर्नर डिफ़ॉल्ट रूप से होता है और इसे तय करने की ज़रूरत नहीं होती. |
<Insets> |
इससे पैनल के लिए इंसर्ट (पैडिंग) तय की जाती है. इसमें left, top, right, bottom एट्रिब्यूट होते हैं. इन इनसेट की जानकारी, पैनल में लॉन्च किए गए ऐप्लिकेशन को दी जाती है.
|
<Background> |
इसमें बैकग्राउंड डेकोर का एक वैकल्पिक पैनल जोड़ा गया है. इससे ऐप्लिकेशन स्विच करते समय, स्क्रीन के आर-पार दिखने वाले इफ़ेक्ट को रोका जा सकेगा. यह डेकोर लेयर के लिए, रंग और ऐल्फ़ा जैसी प्रॉपर्टी तय करता है. डेकोर लेयर की प्रॉपर्टी, जैसे कि बाउंड्री और लेयर, डिफ़ॉल्ट रूप से वैरिएंट की प्रॉपर्टी पर सेट होती हैं. ऐसा तब होता है, जब उन्हें पहले से सेट नहीं किया गया होता है. |
नमूना कोड
<Variant id="@id/opened">
<Visibility isVisible="true"/>
<Bounds left="0dp"
top="0dp"
right="100%"
bottom="100%"
bottomOffset="100dp"/>
<Alpha value="1.0"/>
<Layer value="10"/>
<Focus onTransition="true"/>
<Corner radius="24dp"/>
<Insets left="16dp" top="0dp" right="16dp" bottom="48dp"/>
<Background color="@color/app_background" alpha="0.9"/>
</Variant>
विज़ुअल प्रॉपर्टी इंटरपोलेट करना
विज़ुअल प्रॉपर्टी को इंटरपोलेट करने के लिए, KeyFrameVariant
का इस्तेमाल करें. variant
का यह खास एक्सटेंशन, लगातार फ़्रैक्शनल वैल्यू (0 से 1) पर आधारित होता है. इससे लगातार इनपुट के आधार पर, आसानी से डाइनैमिक ट्रांज़िशन किए जा सकते हैं. जैसे, पैनल की स्थिति को डाइनैमिक तरीके से बदलने के लिए, ड्रैग करने की कार्रवाई.
एक्सएमएल एट्रिब्यूट
KeyFrameVariant
में एट्रिब्यूट मौजूद नहीं हैं. <KeyFrameVariant>
टैग में, KeyFrameVariant
को तय करने के लिए ज़रूरी जानकारी होती है.
एक्सएमएल चाइल्ड एलिमेंट
KeyFrameVariant
में एक या उससे ज़्यादा <KeyFrame>
चाइल्ड टैग शामिल होते हैं. हर <KeyFrame>
में एक framePosition
एट्रिब्यूट (0-100) होता है. यह वैरिएंट एट्रिब्यूट (दूसरे वैरिएंट का आईडी) को दिखाता है. ये keyframes
, लगातार ट्रांज़िशन के दौरान पैनल की स्थिति तय करते हैं.
सैंपल कोड
<KeyFrameVariant id="@id/panel_resizing">
<KeyFrame framePosition="0" variant="@id/minimized"/>
<KeyFrame framePosition="75" variant="@id/opened"/>
<KeyFrame framePosition="100" variant="@id/expanded"/>
</KeyFrameVariant>