मटीरियल डिज़ाइन, यूज़र इंटरफ़ेस (यूआई) एलिमेंट के लिए ऊंचाई उपलब्ध कराता है. ऊंचाई पर पहुंचने से उपयोगकर्ताओं को सहायता मिलती है हर एलिमेंट की अहमियत को समझते हैं और इन चीज़ों पर फ़ोकस करते हैं मौजूदा टास्क को पूरा कर लिया है.
किसी व्यू की ऊंचाई को Z प्रॉपर्टी से दिखाया जाता है. इससे तय होता है कि इसकी परछाई का विज़ुअल तौर पर दिखना. ज़्यादा Z वैल्यू वाले व्यू को ज़्यादा कास्ट किया जाता है, शैडो कम हो जाते हैं और वे कम Z वैल्यू वाले व्यू को छिपा देते हैं. हालांकि, व्यू की Z वैल्यू, व्यू के साइज़ पर असर नहीं डालती है.
एलिवेटेड व्यू के पैरंट की ओर से परछाइयां बनाई जाती हैं. ये इन बातों पर निर्भर करते हैं: स्टैंडर्ड व्यू क्लिपिंग, जिसे माता-पिता डिफ़ॉल्ट रूप से क्लिप करते हैं.
ऐसे ऐनिमेशन बनाने के लिए एलिवेशन का इस्तेमाल करना भी उपयोगी होता है जिनमें विजेट कुछ समय के लिए बढ़ जाते हैं कार्रवाई करते समय व्यू प्लेन के ऊपर सेट करें.
ज़्यादा जानकारी के लिए, यह देखें चढ़ाई में मटीरियल डिज़ाइन.
अपने दृश्यों के लिए ऊंचाई असाइन करें
किसी व्यू के लिए Z वैल्यू में दो कॉम्पोनेंट होते हैं:
- एलिवेशन: स्टैटिक कॉम्पोनेंट
- अनुवाद: ऐनिमेशन के लिए इस्तेमाल किया जाने वाला डाइनैमिक कॉम्पोनेंट
Z = elevation + translationZ
Z वैल्यू को डीपी (डेंसिटी-इंडिपेंडेंट पिक्सल) में मेज़र किया जाता है.
किसी व्यू की डिफ़ॉल्ट (रेस्टिंग) ऊंचाई सेट करने के लिए
एक्सएमएल लेआउट में android:elevation एट्रिब्यूट. ऊंचाई सेट करने के लिए
गतिविधि के कोड में एक दृश्य है, तो इसका उपयोग करें
View.setElevation() अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
तरीका.
किसी व्यू का अनुवाद सेट करने के लिए,
View.setTranslationZ() अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
तरीका.
कॉन्टेंट बनाने
ViewPropertyAnimator.z() अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
और
ViewPropertyAnimator.translationZ()
तरीकों की मदद से, व्यू में होने वाली बढ़ोतरी को ऐनिमेट किया जा सकता है. ज़्यादा जानकारी के लिए, देखें
इसके लिए एपीआई संदर्भ
ViewPropertyAnimator अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
और प्रॉपर्टी
ऐनिमेशन डेवलपर गाइड देखें.
आप यह भी इस्तेमाल कर सकते हैं कि
StateListAnimator अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
डिक्लेरेटिव तरीके से इन ऐनिमेशन को साफ़ तौर पर बताने के लिए. यह खास तौर पर इन कामों के लिए फ़ायदेमंद है
ऐसे मामले जहां स्थिति बदलने पर ऐनिमेशन ट्रिगर होते हैं, जैसे कि जब उपयोगकर्ता किसी बटन पर टैप करता है.
ज़्यादा जानकारी के लिए, यह देखें
ऐनिमेट व्यू
StateListAnimator का इस्तेमाल करके स्थिति में बदलाव करता है.
व्यू के गहरे हिस्सों और आउटलाइन को पसंद के मुताबिक बनाएं
ड्रॉ करने लायक व्यू के बैकग्राउंड की सीमाएं, इस इमेज का डिफ़ॉल्ट आकार तय करती हैं शैडो. आउटलाइन किसी ग्राफ़िक ऑब्जेक्ट का बाहरी आकार दिखाती है और टच फ़ीडबैक के लिए रिपल एरिया को परिभाषित करती है.
इस व्यू पर विचार करें, जिसे ड्रॉ करने लायक बैकग्राउंड के साथ परिभाषित किया गया है:
<TextView android:id="@+id/myview" ... android:elevation="2dp" android:background="@drawable/myrect" />
ड्रॉ करने लायक बैकग्राउंड का मतलब है, रेक्टैंगल और उसके कोने:
<!-- res/drawable/myrect.xml --> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <solid android:color="#42000000" /> <corners android:radius="5dp" /> </shape>
इस व्यू में गोल किनारों वाली परछाई दिखती है, क्योंकि बैकग्राउंड ड्रॉ करने लायक है व्यू की आउटलाइन तय करता है. पसंद के मुताबिक आउटलाइन देने से डिफ़ॉल्ट सेटिंग बदल जाती है की तरह दिखता है.
अपने कोड में किसी व्यू के लिए कस्टम आउटलाइन तय करने के लिए, यह तरीका अपनाएं:
-
ViewOutlineProviderअभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है क्लास. -
getOutline()अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है तरीका. - इसकी मदद से, अपने व्यू के लिए नया आउटलाइन प्रोवाइडर असाइन करें
View.setOutlineProvider()अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है तरीका.
गोल किनारों वाली अंडाकार और आयताकार आउटलाइन बनाई जा सकती हैं. इसके लिए,
तरीका हो सकता है
Outline अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
क्लास. व्यू के लिए डिफ़ॉल्ट आउटलाइन देने वाला टूल,
बैकग्राउंड में दिखता है. किसी दृश्य को शैडो कास्ट करने से रोकने के लिए, उसकी
null को आउटलाइन देने वाला.
क्लिप को मिले व्यू
व्यू क्लिप करने से, व्यू का आकार बदला जा सकता है. आपके पास इतने क्लिप व्यू के लिए क्लिप देखने का विकल्प है
अन्य डिज़ाइन एलिमेंट के साथ कंसिस्टेंसी बनाए रखना या व्यू का आकार बदलना
उपयोगकर्ता के इनपुट का जवाब. किसी व्यू को उसके आउटलाइन वाले हिस्से में क्लिप करने के लिए,
View.setClipToOutline() अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
तरीका. सिर्फ़ वे आउटलाइन जो रेक्टैंगल, वृत्त, और राउंड रेक्टैंगल के साथ काम करती हैं
क्लिपिंग, जैसा कि
Outline.canClip() अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
तरीका.
किसी व्यू को ड्रॉ करने लायक आकार में क्लिप करने के लिए, ड्रॉ करने लायक को
व्यू का बैकग्राउंड—जैसा कि पिछले उदाहरण में दिखाया गया है—और
View.setClipToOutline() तरीका.
व्यू से जुड़ी क्लिप बनाने में बहुत खर्चा आता है. इसलिए, इस्तेमाल किए जाने वाले आकार को ऐनिमेट न करें किसी व्यू को क्लिप करने के लिए. यह इफ़ेक्ट पाने के लिए, रीवील ऐनिमेशन.