विज़ुअल स्टेट को डिज़ाइन करने के लिए किसी वैरिएंट का इस्तेमाल करना

वैरिएंट, पैनल की खास विज़ुअल स्थिति को तय करता है. इससे एक पैनल को अलग-अलग विज़ुअल फ़ॉर्मैट में दिखाया जा सकता है. जैसे, खुला या बंद स्थिति. वैरिएंट को कॉन्फ़िगर करने के लिए, एक्सएमएल का इस्तेमाल करें. <Panel> एलिमेंट में सब-टैग का इस्तेमाल करें.

हर <Variant> टैग में id एट्रिब्यूट होना ज़रूरी है, ताकि उसकी पहचान की जा सके. टैग, पैरंट वैरिएंट का रेफ़रंस भी दे सकता है, ताकि प्रॉपर्टी इनहेरिट की जा सकें. इनहेरिटेंस के इस तरीके से, एक से ज़्यादा वैरिएंट में सामान्य प्रॉपर्टी को बेहतर तरीके से तय किया जा सकता है.

एक्सएमएल एट्रिब्यूट

स्टेट और ट्रांज़िशन तय करने के लिए, इन एट्रिब्यूट का इस्तेमाल <TaskPanel> या <DecorPanel> टैग के साथ करें.

एट्रिब्यूट स्थिति ब्यौरा
id ज़रूरी है वैरिएंट का यूनीक आइडेंटिफ़ायर. इस आईडी का इस्तेमाल, ट्रांज़िशन में वैरिएंट को रेफ़र करने के लिए किया जाता है. इसके अलावा, इसे पैनल के लिए defaultVariant के तौर पर भी इस्तेमाल किया जाता है.
parent वैकल्पिक इस एट्रिब्यूट का इस्तेमाल करके, किसी दूसरे वैरिएंट का आईडी तय किया जाता है. मौजूदा वैरिएंट को इसी वैरिएंट से प्रॉपर्टी इनहेरिट करनी चाहिए. अगर किसी प्रॉपर्टी को मौजूदा वैरिएंट में साफ़ तौर पर तय नहीं किया गया है, तो वह अपने पैरंट वैरिएंट में तय की गई वैल्यू पर वापस आ जाती है.

एक्सएमएल चाइल्ड एलिमेंट

इन ज़रूरी नहीं एलिमेंट का इस्तेमाल करके, पैनल के विज़ुअल की विशेषताओं के बारे में बताएं. ऐसा तब करें, जब पैनल इस वैरिएंट की स्थिति में हो.

चाइल्ड एलिमेंट ब्यौरा
<Visibility> इससे पता चलता है कि पैनल दिख रहा है या छिपा हुआ है. इसमें isVisible एट्रिब्यूट (बूलियन) होता है.
<Alpha> इस एट्रिब्यूट से पैनल की पारदर्शिता का लेवल तय किया जाता है. इसमें alpha एट्रिब्यूट (फ़्लोट, 0.0 से 1.0) होता है.
<Layer> यह पैनल के Z-ऑर्डर को दूसरे पैनल के हिसाब से सेट करता है. इसमें layer एट्रिब्यूट (पूर्णांक) होता है. ज़्यादा वैल्यू को सबसे ऊपर दिखाया जाता है.
<Focus> इससे यह तय होता है कि ट्रांज़िशन के दौरान पैनल पर फ़ोकस किया जा सकता है या नहीं. इसमें onTransition एट्रिब्यूट (बूलियन) होता है.
<Bounds>

स्क्रीन पर पैनल के आयताकार क्षेत्र (जगह और साइज़) को तय करता है. इस एरिया को बाएं, ऊपर, नीचे, चौड़ाई, और ऊंचाई जैसे एट्रिब्यूट से कंट्रोल किया जाता है.

  • left और right, स्क्रीन के बाएं किनारे से दूरी तय करते हैं.
  • top और bottom, स्क्रीन के सबसे ऊपरी किनारे से दूरी तय करते हैं.
  • width और height, रेक्टैंगल की चौड़ाई और ऊंचाई बताते हैं. इनकी ज़रूरत सिर्फ़ तब होती है, जब left और right (या top और bottom) दोनों नहीं दिए गए हों.
  • dimensions को पिक्सल, डीपी, प्रतिशत या संसाधन के रेफ़रंस में तय किया जा सकता है.

प्रतिशत का इस्तेमाल करते समय, ऑफ़सेट एट्रिब्यूट का इस्तेमाल करके, प्रतिशत के आधार पर तय की गई सीमाओं में निश्चित बदलाव लागू किए जा सकते हैं. जैसे, leftOffset, topOffset, rightOffset, और bottomOffset.

उदाहरण के लिए, अगर आपको यह तय करना है कि कोई पैनल, स्क्रीन की पूरी ऊंचाई में दिखे और उसमें नीचे की ओर तय ऊंचाई वाला नेविगेशन बार शामिल न हो, तो ऊंचाई को 100% पर सेट करें. साथ ही, bottomOffset को नेविगेशन बार की तय ऊंचाई पर सेट करें. ऐसा करने पर, पैनल का निचला किनारा ऊपर की ओर खींच जाता है.

<SafeBounds> यह पैनल की सीमाओं के अंदर एक सुरक्षित जगह तय करता है. यह जगह, डिसप्ले कटआउट या इंसर्ट से ओवरलैप नहीं होती है. इससे यह पता चलता है कि इस जगह पर बनाए गए ऐप्लिकेशन, पैनल के साथ काम करते हैं. इसके एट्रिब्यूट, <Bounds> से मिलते-जुलते हैं.
<Corner> यह पैनल के कोनों के लिए रेडियस तय करता है. इससे कोनों को गोल किया जा सकता है. इसमें रेडियस एट्रिब्यूट (पूर्णांक) होता है. शार्प कॉर्नर डिफ़ॉल्ट रूप से सेट होता है और इसे तय करने की ज़रूरत नहीं होती.
<Insets>

इससे पैनल के लिए इंसर्ट (पैडिंग) तय की जाती है. इसमें left, top, right, bottom एट्रिब्यूट होते हैं. इन इनसेट की जानकारी, पैनल में लॉन्च किए गए ऐप्लिकेशन को दी जाती है.

  • left बाईं ओर मौजूद इंसर्ट को तय करता है.
  • right से दाईं ओर मौजूद इंसर्ट के बारे में पता चलता है. उदाहरण के लिए, शून्य राइट इंसर्ट का मतलब है कि दाईं ओर कोई इंसर्ट नहीं है.
  • top से ऊपर की ओर मौजूद इंसर्ट के बारे में पता चलता है.
  • 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>