ड्रॉ करने लायक संसाधन, एक ऐसे ग्राफ़िक का सामान्य सिद्धांत है जिसे स्क्रीन पर बनाया जा सकता है
आप getDrawable(int) जैसे एपीआई की मदद से वापस पा सकते हैं या लागू कर सकते हैं
को android:drawable और android:icon जैसे एट्रिब्यूट के साथ किसी दूसरे एक्सएमएल रिसॉर्स में जोड़ना होगा.
ड्रॉबल के कई तरीके होते हैं:
  - बिटमैप फ़ाइल
 - 
    
 - बिट मैप ग्राफ़िक फ़ाइल (PNG, WebP, JPG या GIF).
      यह 
BitmapDrawable बनाता है. 
  - नाइन-पैच फ़ाइल
 
    - ऐसी PNG फ़ाइल जिसमें कॉन्टेंट के हिसाब से साइज़ बदलने की सुविधा हो और इमेज का साइज़ बदला जा सके (
.9.png). NinePatchDrawable बनाता है. 
  - लेयर सूची
 
    - ड्रॉ करने लायक ऐसा डिवाइस जो दूसरे ड्रॉ करने लायक आइटम के कलेक्शन को मैनेज करता है. इन्हें अरे के क्रम में बनाया जाता है, इसलिए
सबसे बड़े इंडेक्स वाले एलिमेंट को सबसे ऊपर दिखाया जाता है. यह 
LayerDrawable बनाता है. 
  - राज्यों की सूची
 
    - ऐसी एक्सएमएल फ़ाइल जो अलग-अलग बिटमैप ग्राफ़िक का रेफ़रंस देती है
    अलग-अलग स्थितियों के लिए—उदाहरण के लिए, किसी बटन पर टैप किए जाने पर किसी दूसरी इमेज का इस्तेमाल करना.
    यह 
StateListDrawable बनाता है. 
  - लेवल की सूची
 
    - ड्रॉइंग फ़ाइल के बारे में बताने वाली एक्सएमएल फ़ाइल, जो कई वैकल्पिक ड्रॉबल को मैनेज करती है. हर फ़ाइल में
असाइन की गई ज़्यादा से ज़्यादा संख्या वाली वैल्यू डाली गई है. यह 
LevelListDrawable बनाता है. 
  - ड्रॉइंग ड्रॉ करने की सुविधा
 
    - ऐसी एक्सएमएल फ़ाइल जो ड्रॉ करने लायक के बारे में बताती है, जो ड्रॉ करने लायक दो रिसॉर्स के बीच क्रॉस-फ़ेड हो सकती है.
यह 
TransitionDrawable बनाता है. 
  - इनसेट ड्रॉ करने लायक
 
    - ड्रॉ करने लायक ऐसी एक्सएमएल फ़ाइल जिसमें तय की गई दूरी से, ड्रॉ किए जा सकने वाले किसी अन्य एलिमेंट को इनसेट में शामिल किया जाता है.
यह तब काम आता है, जब किसी व्यू के लिए ड्रॉ करने लायक बैकग्राउंड की ज़रूरत हो और वह व्यू के असल बैकग्राउंड से छोटा हो
सीमाओं.
 
  - क्लिप ड्रॉ करने लायक
 
    - ऐसी एक्सएमएल फ़ाइल जो ड्रॉएबल के बारे में जानकारी देती है. यह फ़ाइल, इस ड्रॉएबल के
मौजूदा लेवल की वैल्यू. यह 
ClipDrawable बनाता है. 
  - ड्रॉ करने लायक स्केल
 
    - ऐसी एक्सएमएल फ़ाइल जो ड्रॉएबल के बारे में बताती है. यह फ़ाइल, ड्रॉ करने लायक किसी अन्य एलिमेंट के साइज़ को उसके
मौजूदा लेवल की वैल्यू.  इससे 
ScaleDrawable बनता है 
  - ड्रॉ करने लायक आकार.
 
    - ऐसी एक्सएमएल फ़ाइल जो ज्यामितीय आकार को परिभाषित करती है. इसमें रंग और ग्रेडिएंट भी शामिल होते हैं.
    यह 
GradientDrawable बनाता है. 
यह जानने के लिए कि
  AnimationDrawable बनाएं,
  ऐनिमेशन संसाधन दस्तावेज़ देखें.
ध्यान दें: रंग का रिसॉर्स
एक्सएमएल में ड्रॉ करने लायक के तौर पर इस्तेमाल किया जाता है. उदाहरण के लिए, राज्यों की सूची बनाते समय
ड्रॉ करने लायक है, तो आप android:drawable एट्रिब्यूट (android:drawable="@color/green") के लिए रंग से जुड़े संसाधन का संदर्भ ले सकते हैं.
बिट मैप
बिट मैप इमेज. Android पर इन फ़ॉर्मैट में बिटमैप फ़ाइलें काम करती हैं:
PNG (पसंदीदा), WebP (पसंदीदा, एपीआई लेवल 17 या उसके बाद के लेवल की ज़रूरत है), JPG (स्वीकार करने लायक), GIF (अस्वीकार किया गया).
आप संसाधन आईडी के रूप में फ़ाइल नाम का उपयोग करके, किसी बिटमैप फ़ाइल का सीधे संदर्भ दे सकते हैं, या कोई
एक्सएमएल में, उपनाम का संसाधन आईडी.
ध्यान दें: बिटमैप फ़ाइलें लॉसलेस के साथ अपने-आप ऑप्टिमाइज़ हो सकती हैं
बिल्ड प्रोसेस के दौरान aapt टूल की मदद से इमेज को कंप्रेस करने की सुविधा. इसके लिए
उदाहरण के लिए, किसी असली रंग की PNG फ़ाइल को 8-बिट में बदला जा सकता है, जिसमें 256 से ज़्यादा रंगों की ज़रूरत न हो
रंग पटल के साथ PNG फ़ॉर्मैट. इससे एक जैसी क्वालिटी की इमेज मिलती है, जिसे कम
मेमोरी.
इसलिए, ध्यान रखें कि इस डायरेक्ट्री में मौजूद इमेज बाइनरी, बिल्ड के दौरान बदल सकती हैं. अगर आपने
किसी इमेज को बिट स्ट्रीम के रूप में पढ़ने की योजना है, ताकि उसे बिट मैप में बदला जा सके, अपनी इमेज को
res/raw/ फ़ोल्डर का इस्तेमाल करना चाहिए, जहां उन्हें ऑप्टिमाइज़ नहीं किया जाता है.
बिटमैप फ़ाइल
बिट मैप फ़ाइल PNG, WebP, JPG या GIF फ़ाइल होती है. Android, Drawable बनाता है
इनमें से किसी भी फ़ाइल के लिए संसाधन तब लागू होगा, जब आप उन्हें res/drawable/ डायरेक्ट्री में सेव करेंगे.
- फ़ाइल की जगह:
 
res/drawable/filename.png (.png, .webp, .jpg या .gif)
फ़ाइल का नाम, संसाधन आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
BitmapDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- उदाहरण:
 
res/drawable/myimage.png पर सेव की गई इमेज के साथ, यह लेआउट एक्सएमएल लागू होता है
किसी व्यू पर इमेज जोड़ने के लिए:
<ImageView
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    android:src="@drawable/myimage" />
नीचे दिया गया ऐप्लिकेशन कोड, इमेज को Drawable के तौर पर फिर से लेता है:
Kotlin
val drawable: Drawable? = ResourcesCompat.getDrawable(resources, R.drawable.myimage, null)
 
 
- यह भी देखें:
 
- 
 
एक्सएमएल बिटमैप
एक्सएमएल बिटमैप, एक्सएमएल में तय किया गया एक ऐसा संसाधन है जो किसी बिटमैप फ़ाइल पर ले जाता है. यह प्रभाव
रॉ बिटमैप फ़ाइल. XML बिटमैप के लिए अतिरिक्त गुण बता सकता है, जैसे कि डिदरिंग और टाइलिंग.
ध्यान दें: <bitmap> एलिमेंट का इस्तेमाल इनके चाइल्ड के तौर पर किया जा सकता है
एक <item> एलिमेंट. इसके लिए
उदाहरण के लिए, राज्यों की सूची या लेयर सूची बनाते समय,
आप android:drawable को निकाल सकते हैं
<item> एलिमेंट से एट्रिब्यूट जोड़ें और उसके अंदर <bitmap> को नेस्ट करें
जो ड्रॉ किए जा सकने वाले आइटम के बारे में बताता है.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
BitmapDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<bitmap
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:src="@[package:]drawable/drawable_resource"
    android:antialias=["true" | "false"]
    android:dither=["true" | "false"]
    android:filter=["true" | "false"]
    android:gravity=["top" | "bottom" | "left" | "right" | "center_vertical" |
                      "fill_vertical" | "center_horizontal" | "fill_horizontal" |
                      "center" | "fill" | "clip_vertical" | "clip_horizontal"]
    android:mipMap=["true" | "false"]
    android:tileMode=["disabled" | "clamp" | "repeat" | "mirror"] />
 
- एलिमेंट:
 
- 
  <bitmap> 
    - ज़रूरी है. बिटमैप सोर्स और उसकी प्रॉपर्टी के बारे में बताता है.
      
विशेषताएं:
      
        xmlns:android 
          - स्ट्रिंग. एक्सएमएल नेमस्पेस तय करता है, जिसे
          
"http://schemas.android.com/apk/res/android". यह सिर्फ़ तब ज़रूरी होता है, जब
<bitmap> रूट एलिमेंट है. इसकी ज़रूरत नहीं है, क्योंकि
<bitmap> को <item> में नेस्ट किया गया है. 
        android:src 
          - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का रेफ़रंस
संसाधन.
 
        android:antialias 
          - बूलियन. एंटीएलियाज़िंग को चालू या बंद करती है.
 
        android:dither 
          - बूलियन. अगर बिट मैप काम नहीं करता है, तो इससे बिट मैप में डेटा को डिदर करने की सुविधा चालू या बंद होती है
उनका पिक्सल कॉन्फ़िगरेशन स्क्रीन के जैसा ही होता है, जैसे कि RGB 565 पर ARGB 8888 बिटमैप
स्क्रीन.
 
        android:filter 
          - बूलियन. बिट मैप फ़िल्टर करने की सुविधा को चालू या बंद करता है. फ़िल्टर करने की सुविधा का इस्तेमाल तब किया जाता है, जब
बिट मैप के दिखने का तरीका बेहतर बनाने के लिए छोटा या बढ़ाया जाता है.
 
        android:gravity 
          - कीवर्ड. बिट मैप का गुरुत्वाकर्षण तय करता है. गुरुत्वाकर्षण संकेत देता है कि
अगर बिट मैप कंटेनर से छोटा है, तो ड्रॉएबल को उसके कंटेनर में रखें.
            
इनमें से एक या एक से ज़्यादा कॉन्सटेंट वैल्यू होनी चाहिए, जिन्हें | से अलग किया गया हो:
| वैल्यू | ब्यौरा | 
top | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के ऊपर रखें. | 
bottom | 
ऑब्जेक्ट को उसके कंटेनर के नीचे रखें, उसका आकार बदले बिना.  | 
left | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना उसके कंटेनर के बाएं किनारे पर रखें.  | 
right | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना उसके कंटेनर के दाएं किनारे पर रखें.  | 
center_vertical | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के वर्टिकल सेंटर में रखें.  | 
fill_vertical | 
अगर ज़रूरी हो, तो ऑब्जेक्ट का वर्टिकल साइज़ बढ़ाएं, ताकि यह अपने कंटेनर को पूरी तरह से भर सके.  | 
center_horizontal | 
ऑब्जेक्ट को उसके कंटेनर के हॉरिज़ॉन्टल सेंटर में रखें, उसका साइज़ बदले बिना.  | 
fill_horizontal | 
अगर ज़रूरत हो, तो ऑब्जेक्ट का हॉरिज़ॉन्टल साइज़ बढ़ाएं, ताकि यह अपने कंटेनर को पूरी तरह से भर सके.
 | 
center | 
ऑब्जेक्ट को उसके कंटेनर के बीच में वर्टिकल और हॉरिज़ॉन्टल, दोनों ऐक्सिस में रखें, न कि
उसका आकार बदल रहा है.  | 
fill | 
अगर ज़रूरत हो, तो ऑब्जेक्ट का हॉरिज़ॉन्टल और वर्टिकल साइज़ बड़ा करें, ताकि यह ऑब्जेक्ट को पूरी तरह से भर सके
कंटेनर. यह डिफ़ॉल्ट विकल्प है. | 
clip_vertical | 
बच्चे के ऊपरी और/या निचले किनारों को क्लिप करने के लिए सेट किया जा सकने वाला अन्य विकल्प
उसके कंटेनर की सीमाएं शामिल होती हैं. यह क्लिप लंबवत गुरुत्वाकर्षण पर आधारित है: शीर्ष गुरुत्वाकर्षण क्लिप
निचला किनारा, निचला गुरुत्वाकर्षण ऊपरी किनारे को क्लिप करता है, और कोई भी दोनों किनारों को क्लिप नहीं करता है.
 | 
clip_horizontal | 
दूसरा विकल्प, जिसे इस तरह सेट किया जा सकता है कि बच्चे के बाएं और/या दाएं किनारे क्लिप किए जाएं
उसके कंटेनर की सीमाएं शामिल होती हैं. यह क्लिप हॉरिज़ॉन्टल गुरुत्वाकर्षण पर आधारित है: बायां गुरुत्वाकर्षण क्लिप
दायां किनारा, दायां गुरुत्वाकर्षण, बाएं किनारे को क्लिप करता है, और कोई भी दोनों किनारों को क्लिप नहीं करता है.
 | 
           
        android:mipMap 
          - बूलियन. मिपमैप संकेत को चालू या बंद करता है. ज़्यादा जानकारी के लिए, 
setHasMipMap() पर जाएं.
          डिफ़ॉल्ट मान असत्य है. 
        android:tileMode 
          - कीवर्ड. टाइल मोड के बारे में बताता है. टाइल मोड के सक्षम होने पर, बिटमैप
दोहराया गया. टाइल मोड चालू होने पर, ग्रेविटी को अनदेखा कर दिया जाता है.
            
इनमें से कोई एक कॉन्सटैंट वैल्यू होनी चाहिए:
| वैल्यू | ब्यौरा | 
disabled | 
बिटमैप को टाइल न करें. यह डिफ़ॉल्ट मान है. | 
clamp | 
अगर शेडर अपनी मूल सीमाओं से बाहर खींचता है, तो किनारे का रंग दोहराएं | 
repeat | 
शेडर की इमेज को हॉरिज़ॉन्टल या वर्टिकल तौर पर दोहराएं. | 
mirror | 
शेडर की इमेज को हॉरिज़ॉन्टल या वर्टिकल तौर पर, अलग-अलग मिरर इमेज को दोहराएं, ताकि
आस-पास की इमेज को हमेशा जोड़ें. | 
           
      
     
  
- उदाहरण:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<bitmap xmlns:android="http://schemas.android.com/apk/res/android"
    android:src="@drawable/icon"
    android:tileMode="repeat" />
 
- यह भी देखें:
 
- 
 
नाइन-पैच
NinePatch एक PNG इमेज होती है, जिसमें स्ट्रेच किए जा सकने वाले इलाके तय किए जा सकते हैं
जिसे Android तब स्केल करता है, जब व्यू में मौजूद कॉन्टेंट, इमेज की सामान्य सीमाओं से ज़्यादा हो जाता है. आपने लोगों तक पहुंचाया मुफ़्त में
आम तौर पर, इस तरह की इमेज को उस व्यू के बैकग्राउंड के तौर पर असाइन करते हैं जिसमें कम से कम एक डाइमेंशन सेट हो
"wrap_content" तक.
कॉन्टेंट के हिसाब से व्यू बढ़ने पर, 9-पैच वाली इमेज
को भी व्यू के साइज़ से मैच करने के लिए स्केल किया जाता है. नौ पैच वाली इमेज के इस्तेमाल का उदाहरण
बैकग्राउंड का इस्तेमाल, Android के स्टैंडर्ड Button विजेट के लिए किया जाता है. यह विजेट,
टेक्स्ट (या चित्र) को बटन के अंदर समायोजित कर सकता है.
किसी सामान्य बिटमैप की तरह, आप नौ-पैच फ़ाइल का सीधे रेफ़रंस दे सकते हैं
या एक्सएमएल के ज़रिए तय किए गए किसी संसाधन से.
स्ट्रैच किए जा सकने वाले इलाकों वाली नाइन-पैच फ़ाइल बनाने के बारे में पूरी जानकारी पाने के लिए,
साइज़ बदलने लायक बिटमैप (9-पैच फ़ाइलें) बनाना देखें.
नाइन-पैच फ़ाइल
- फ़ाइल की जगह:
 
res/drawable/filename.9.png
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
NinePatchDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- उदाहरण:
 
res/drawable/myninepatch.9.png पर सेव की गई इमेज के साथ, यह लेआउट एक्सएमएल
किसी व्यू पर नौ पैच लागू करता है:
<Button
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    android:background="@drawable/myninepatch" />
 
- यह भी देखें:
 
- 
 
एक्सएमएल नाइन-पैच
एक्सएमएल में नाइन-पैच एक ऐसा संसाधन है जो नौ पैच वाली फ़ाइल पर ले जाता है. एक्सएमएल यह कर सकती है
चित्र के लिए डायदरिंग तय करें.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
NinePatchDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<nine-patch
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:src="@[package:]drawable/drawable_resource"
    android:dither=["true" | "false"] />
 
- एलिमेंट:
 
- 
  <nine-patch> 
    - ज़रूरी है. नौ पैच सोर्स और उसकी प्रॉपर्टी के बारे में बताता है.
      
विशेषताएं:
      
        xmlns:android 
          - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
          
"http://schemas.android.com/apk/res/android".
         android:src 
          - ड्रॉ करने लायक संसाधन. ज़रूरी है. नाइन-पैच का रेफ़रंस
फ़ाइल से लिए जाते हैं.
 
        android:dither 
          - बूलियन. अगर बिट मैप काम नहीं करता है, तो इससे बिट मैप में डेटा को डिदर करने की सुविधा चालू या बंद होती है
उनका पिक्सल कॉन्फ़िगरेशन स्क्रीन के जैसा ही होता है, जैसे कि RGB 565 पर ARGB 8888 बिटमैप
स्क्रीन.
 
      
     
 
- उदाहरण:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<nine-patch xmlns:android="http://schemas.android.com/apk/res/android"
    android:src="@drawable/myninepatch"
    android:dither="false" />
 
लेयर की सूची
LayerDrawable एक ड्रॉ करने लायक ऑब्जेक्ट है
जो अन्य ड्रॉ करने लायक आइटम की कैटगरी को मैनेज करता है. सूची में ड्रॉ की जाने वाली हर चीज़,
सूची. सूची में अंतिम ड्रॉएबल शीर्ष पर बनाया जाता है.
ड्रॉएबल की हर सुविधा को, एक <layer-list> एलिमेंट में मौजूद <item> एलिमेंट से दिखाया जाता है.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
LayerDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<layer-list
    xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:drawable="@[package:]drawable/drawable_resource"
        android:id="@[+][package:]id/resource_name"
        android:top="dimension"
        android:right="dimension"
        android:bottom="dimension"
        android:left="dimension" />
</layer-list>
 
- एलिमेंट:
 
- 
  <layer-list> 
    - ज़रूरी है. यह रूट एलिमेंट होना चाहिए. एक या ज़्यादा 
<item> एलिमेंट शामिल हैं.
      विशेषताएं:
      
        xmlns:android 
          - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
          
"http://schemas.android.com/apk/res/android".
       
     
  <item> 
    - ड्रॉ करने लायक लेयर में, ड्रॉ करने लायक ऐसी जगह तय करता है जो इसके एट्रिब्यूट के हिसाब से तय होती है.
<layer-list> एलिमेंट का चाइल्ड होना चाहिए. चाइल्ड <bitmap> स्वीकार किया जाता है
एलिमेंट.
      विशेषताएं:
      
        android:drawable 
          - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का रेफ़रंस
संसाधन.
 
        android:id 
          - संसाधन आईडी. ड्रॉएबल के लिए यूनीक संसाधन आईडी. नया संसाधन बनाने के लिए
इस आइटम का आईडी, इस फ़ॉर्म का इस्तेमाल करें:
"@+id/name". प्लस का चिह्न संकेत देता है कि इसे एक नए नाम के रूप में बनाया गया है
आईडी. इस आइडेंटिफ़ायर का इस्तेमाल इन कामों के लिए किया जा सकता है
ड्रॉएबल को View.findViewById() या Activity.findViewById() की मदद से वापस पाएं और उसमें बदलाव करें. 
        android:top 
          - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, ऊपर का ऑफ़सेट.
 
        android:right 
          - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर दायां ऑफ़सेट.
 
        android:bottom 
          - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, सबसे नीचे मौजूद ऑफ़सेट.
 
        android:left 
          - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर बायां ऑफ़सेट.
 
      
      ड्रॉ किए जा सकने वाले सभी आइटम का साइज़, उसे डिफ़ॉल्ट तौर पर व्यू के साइज़ में फ़िट करने के लिए स्केल किया जाता है. इसलिए,
अपनी इमेज को अलग-अलग जगह पर लेयर सूची में रखने से व्यू का साइज़ बढ़ सकता है और
कुछ इमेज के साइज़ को ज़रूरत के हिसाब से स्केल भी किया जा सकता है.
इससे बचने के लिए
सूची में मौजूद आइटम को स्केल करें, ड्रॉ करने लायक बताने के लिए <item> एलिमेंट में <bitmap> एलिमेंट का इस्तेमाल करें. साथ ही, किसी ऐसी चीज़ के लिए ग्रैविटी तय करें जो उससे जुड़ी हुई नहीं है
स्केल, जैसे कि "center". उदाहरण के लिए, नीचे दिया गया <item> किसी आइटम के बारे में बताता है
जो अपने कंटेनर व्यू में फ़िट होने के लिए फ़िट हो जाता है:
<item android:drawable="@drawable/image" />
इस उदाहरण में, स्केलिंग से बचने के लिए, बीच में मौजूद <bitmap> एलिमेंट का इस्तेमाल किया गया है
गुरुत्वाकर्षण:
<item>
  <bitmap android:src="@drawable/image"
          android:gravity="center" />
</item>
     
  
- उदाहरण:
 
- एक्सएमएल फ़ाइल 
res/drawable/layers.xml पर सेव की गई:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
      <bitmap android:src="@drawable/android_red"
        android:gravity="center" />
    </item>
    <item android:top="10dp" android:left="10dp">
      <bitmap android:src="@drawable/android_green"
        android:gravity="center" />
    </item>
    <item android:top="20dp" android:left="20dp">
      <bitmap android:src="@drawable/android_blue"
        android:gravity="center" />
    </item>
</layer-list>
इस उदाहरण में, ड्रॉ करने लायक एट्रिब्यूट के बारे में बताने के लिए, नेस्ट किए गए <bitmap> एलिमेंट का इस्तेमाल किया गया है
"center" ग्रैविटी वाले हर आइटम के लिए संसाधन. इससे पक्का होता है कि कोई भी इमेज,
कंटेनर के साइज़ को फ़िट कर सकते हैं, क्योंकि ऑफ़सेट इमेज की वजह से साइज़ बदलना है.
यह लेआउट एक्सएमएल किसी व्यू पर ड्रॉएबल लागू करता है:
<ImageView
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    android:src="@drawable/layers" />
इसकी वजह से, मुझे ऑफ़सेट वाली इमेज का एक स्टैक मिल गया है:
  
- यह भी देखें:
 
- 
 
राज्य की सूची
StateListDrawable, ड्रॉ करने लायक ऑब्जेक्ट है. इसके बारे में एक्सएमएल में बताया गया है
जिसमें एक ही ग्राफ़िक को दिखाने के लिए कई इमेज का इस्तेमाल किया गया है. यह सुविधा,
ऑब्जेक्ट को हाइलाइट करने की सुविधा मिलती है. उदाहरण के लिए, Button के विजेट की स्थिति पर टैप करके, फ़ोकस किया जा सकता है,
या कोई नहीं; ड्रॉ करने लायक राज्य की सूची का इस्तेमाल करके, हर एक फ़ाइल के लिए अलग-अलग बैकग्राउंड इमेज दी जा सकती है
राज्य.
एक्सएमएल फ़ाइल में, राज्यों की सूची के बारे में बताया गया हो. हर ग्राफ़िक को <selector> एलिमेंट में मौजूद <item> एलिमेंट से दिखाया जाता है. हर <item>
उस स्थिति के बारे में बताने के लिए अलग-अलग एट्रिब्यूट का इस्तेमाल करता है जिसमें इसे ग्राफ़िक के तौर पर इस्तेमाल किया जाता है
ड्रॉ करने लायक है.
हर स्थिति में बदलाव के दौरान, राज्य की सूची ऊपर से नीचे दिखाई जाती है. साथ ही, सूची में पहला आइटम जो
का इस्तेमाल किया गया है. यह चुनाव "सबसे अच्छे" के आधार पर नहीं है
मैच करता है," बल्कि पहला आइटम जो राज्य के तय की गई शर्तों को पूरा करता हो.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
StateListDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"
    android:constantSize=["true" | "false"]
    android:dither=["true" | "false"]
    android:variablePadding=["true" | "false"] >
    <item
        android:drawable="@[package:]drawable/drawable_resource"
        android:state_pressed=["true" | "false"]
        android:state_focused=["true" | "false"]
        android:state_hovered=["true" | "false"]
        android:state_selected=["true" | "false"]
        android:state_checkable=["true" | "false"]
        android:state_checked=["true" | "false"]
        android:state_enabled=["true" | "false"]
        android:state_activated=["true" | "false"]
        android:state_window_focused=["true" | "false"] />
</selector>
 
- एलिमेंट:
 
- 
  <selector> 
    - ज़रूरी है. यह रूट एलिमेंट होना चाहिए. एक या ज़्यादा 
<item> एलिमेंट शामिल हैं.
      विशेषताएं:
      
        xmlns:android 
          - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
          
"http://schemas.android.com/apk/res/android".
         android:constantSize 
          - बूलियन. अगर ड्रॉएबल के रिपोर्ट किए गए अंदरूनी साइज़ की स्थिति में बदलाव नहीं होता है, तो सही है
बदलाव (सभी राज्यों में साइज़ ज़्यादा से ज़्यादा नहीं होना चाहिए); अगर इवेंट साइज़ के हिसाब से साइज़ अलग-अलग है, तो गलत
मौजूदा स्थिति. डिफ़ॉल्ट रूप से, यह वैल्यू 'गलत' पर सेट होती है.
 
        android:dither 
          - बूलियन. अगर बिट मैप में वही पिक्सेल नहीं है, तो बिट मैप में डायदरिंग सक्षम करने के लिए सही
स्क्रीन जैसा कॉन्फ़िगरेशन, जैसे कि RGB 565 स्क्रीन पर ARGB 8888 बिटमैप; गलत
डीदरिंग बंद करें. डिफ़ॉल्ट रूप से, 'सही' होता है.
 
        android:variablePadding 
          - बूलियन. अगर ड्रॉएबल की पैडिंग, मौजूदा ट्रैफ़िक के हिसाब से बदलती है, तो वैल्यू 'सही' होगी
चुना गया राज्य; अगर पैडिंग अधिकतम सीमा पर आधारित है, तो
सभी राज्यों की पैडिंग (जगह) शामिल है. इस सुविधा को चालू करने के लिए ज़रूरी है कि आप
स्थिति बदलने पर लेआउट करता है, जो अक्सर काम नहीं करता. डिफ़ॉल्ट रूप से, यह वैल्यू 'गलत' पर सेट होती है.
 
      
     
  <item> 
    - यह तय करता है कि कुछ राज्यों में, ड्रॉ किए जा सकने वाले एलिमेंट का इस्तेमाल किया जा सकेगा. इसके बारे में एट्रिब्यूट के बारे में बताया गया है. 
<selector> एलिमेंट का चाइल्ड.
      विशेषताएं:
      
        android:drawable 
          - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉ करने लायक संसाधन का रेफ़रंस.
 
        android:state_pressed 
          - बूलियन. अगर इस आइटम का इस्तेमाल, ऑब्जेक्ट पर टैप किए जाने पर किया जाता है, तो वैल्यू 'सही' होगी. जैसे, जब किसी बटन पर टैप किया गया हो
छुआ जाता है; अगर इस आइटम का इस्तेमाल डिफ़ॉल्ट और बिना टैप किए हुए तरीके में किया जाता है, तो यह गलत है.
 
        android:state_focused 
          - बूलियन. अगर ऑब्जेक्ट में इनपुट फ़ोकस मौजूद होने पर इस आइटम का इस्तेमाल किया जाता है, तो वैल्यू 'सही' होगी,
जैसे, जब उपयोगकर्ता कोई टेक्स्ट इनपुट चुनता है; गलत है, अगर इस आइटम का डिफ़ॉल्ट रूप से इस्तेमाल किया जाता है,
फ़ोकस नहीं किया जा सकता.
 
        android:state_hovered 
          - बूलियन. सही है, अगर इस आइटम का इस्तेमाल तब किया जाता है, जब कर्सर को ऑब्जेक्ट पर घुमाया जाता है;
अगर इस आइटम का इस्तेमाल डिफ़ॉल्ट, बिना कर्सर वाले स्थिति में किया जाता है, तो यह गलत है. अक्सर, यह
ड्रॉएबल उसी ड्रॉएबल का इस्तेमाल किया जा सकता है जिसका इस्तेमाल "फ़ोकस किया गया" राज्य.
          
एपीआई लेवल 14 में पेश किया गया.
 
        android:state_selected 
          - बूलियन. अगर इस आइटम का इस्तेमाल तब किया जाता है, जब ऑब्जेक्ट मौजूदा है
डायरेक्शनल कंट्रोल के साथ नेविगेट करते समय, उपयोगकर्ता को चुनना. जैसे, सूची में नेविगेट करते समय
डी-पैड के साथ; अगर इस आइटम का इस्तेमाल तब किया जाता है, जब ऑब्जेक्ट को नहीं चुना जाता, तो यह गलत होती है.
चुनी गई स्थिति का इस्तेमाल तब किया जाता है, जब android:state_focused काफ़ी न हो.
जैसे, जब सूची के व्यू में फ़ोकस हो और इसके अंदर मौजूद किसी आइटम को डी-पैड से चुना गया हो.
 
        android:state_checkable 
          - बूलियन. अगर इस आइटम का इस्तेमाल तब किया जाता है, जब ऑब्जेक्ट को चुना जा सकता है, तो 'सही'; गलत है, अगर यह
आइटम का इस्तेमाल तब किया जाता है, जब ऑब्जेक्ट चुनने लायक न हो. यह सिर्फ़ तब काम आता है, जब ऑब्जेक्ट यह कर सके
चुनने और न चुनने लायक विजेट के बीच ट्रांज़िशन.
 
        android:state_checked 
          - बूलियन. अगर इस आइटम का इस्तेमाल, ऑब्जेक्ट के चुने जाने पर किया जाता है, तो 'सही'; गलत है, अगर यह
का इस्तेमाल तब किया जाता है, जब ऑब्जेक्ट से चुना हुआ का निशान हटा दिया जाता है.
 
        android:state_enabled 
          - बूलियन. अगर इस आइटम का इस्तेमाल ऑब्जेक्ट के चालू होने पर किया जाता है, तो सही है,
जिसका मतलब है टच या क्लिक इवेंट पाने की सुविधा; गलत है अगर इसका इस्तेमाल तब किया जाता है जब ऑब्जेक्ट
बंद किया गया.
 
        android:state_activated 
          - बूलियन. सही है, अगर इस आइटम का इस्तेमाल तब किया जाता है, जब ऑब्जेक्ट को इस तौर पर चालू किया जाता है
स्थायी चुनाव, जैसे कि "हाइलाइट" स्थायी सूची में पहले से चुना गया सूची आइटम
नेविगेशन व्यू; अगर ऑब्जेक्ट के चालू न होने पर इसका इस्तेमाल किया जाता है, तो यह वैल्यू गलत होती है.
एपीआई लेवल 11 में पेश किया गया.
 
        android:state_window_focused 
          - बूलियन. 'सही है' अगर इस आइटम का इस्तेमाल तब किया जाता है जब ऐप्लिकेशन विंडो पर फ़ोकस हो, यानी
ऐप्लिकेशन को फ़ोरग्राउंड में दिखाया गया हो; गलत है, अगर ऐप्लिकेशन में इस आइटम का इस्तेमाल किया जाता है
विंडो पर फ़ोकस नहीं होता, उदाहरण के लिए, अगर नोटिफ़िकेशन शेड नीचे खींचा गया हो या कोई डायलॉग दिखता हो.
 
      
      ध्यान दें: Android, इन स्थितियों की सूची में पहला आइटम लागू करता है
ऑब्जेक्ट की मौजूदा स्थिति से मेल खाता है. इसलिए, अगर सूची के पहले आइटम में
कोई भी पिछली राज्य विशेषता नहीं है, तो यह हर बार लागू होता है. इसलिए, आपको अपने
डिफ़ॉल्ट वैल्यू को हमेशा आखिरी के तौर पर सेट करें, जैसा कि इस उदाहरण में दिखाया गया है.
     
  
- उदाहरण:
 
- एक्सएमएल फ़ाइल 
res/drawable/button.xml पर सेव की गई:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true"
          android:drawable="@drawable/button_pressed" /> <!-- pressed -->
    <item android:state_focused="true"
          android:drawable="@drawable/button_focused" /> <!-- focused -->
    <item android:state_hovered="true"
          android:drawable="@drawable/button_focused" /> <!-- hovered -->
    <item android:drawable="@drawable/button_normal" /> <!-- default -->
</selector>
यह लेआउट एक्सएमएल, बटन पर क्लिक की जा सकने वाली स्थिति की सूची को लागू करता है:
<Button
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    android:background="@drawable/button" />
  
- यह भी देखें:
 
- 
 
लेवल की सूची
यह एक ऐसा ड्रॉबल है जो कई वैकल्पिक आइटम को मैनेज करता है. साथ ही, हर एक को एक तय संख्या असाइन की जाती है
वैल्यू. setLevel() के साथ ड्रॉएबल का लेवल मान सेट करने से ड्रॉ करने लायक संसाधन इसमें लोड होता है
स्तर सूची जिसमें android:maxLevel मान से ज़्यादा या उसके बराबर है
पास की गई है.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
LevelListDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<level-list
    xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:drawable="@drawable/drawable_resource"
        android:maxLevel="integer"
        android:minLevel="integer" />
</level-list>
 
- एलिमेंट:
 
- 
  <level-list> 
  - ज़रूरी है. यह रूट एलिमेंट होना चाहिए. एक या ज़्यादा 
<item> एलिमेंट शामिल हैं.
    विशेषताएं:
    
      xmlns:android 
        - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
        
"http://schemas.android.com/apk/res/android".
     
   
  <item> 
  - खास लेवल पर इस्तेमाल किए जाने वाले ड्रॉएबल के बारे में बताता है.
    
विशेषताएं:
    
      android:drawable 
        - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का रेफ़रंस
संसाधन को इनसेट में बदलें.
 
      android:maxLevel 
        - पूरी संख्या. इस आइटम के लिए अनुमति वाला ज़्यादा से ज़्यादा लेवल.
 
      android:minLevel 
        - पूरी संख्या. इस आइटम के लिए अनुमति का कम से कम लेवल.
 
    
   
 
- उदाहरण:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<level-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:drawable="@drawable/status_off"
        android:maxLevel="0" />
    <item
        android:drawable="@drawable/status_on"
        android:maxLevel="1" />
</level-list>
इसे View पर लागू करने के बाद, setLevel() या setImageLevel() से लेवल को बदला जा सकता है.
 
- यह भी देखें:
 
- 
 
ड्रॉ करने लायक ट्रांज़िशन
TransitionDrawable एक ड्रॉ करने लायक ऑब्जेक्ट है
जो दो अन्य ड्रॉ करने लायक संसाधनों के बीच क्रॉस-फ़ेड हो सकता है.
ड्रॉएबल की हर सुविधा को, एक <transition> एलिमेंट में मौजूद <item> एलिमेंट से दिखाया जाता है. दो से ज़्यादा आइटम का इस्तेमाल नहीं किया जा सकता. ट्रांज़िशन को आगे बढ़ाने के लिए, कॉल करें
startTransition(). यहां की यात्रा पर हूं
पीछे जाने के लिए, reverseTransition() पर कॉल करें.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
TransitionDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<transition
xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:drawable="@[package:]drawable/drawable_resource"
        android:id="@[+][package:]id/resource_name"
        android:top="dimension"
        android:right="dimension"
        android:bottom="dimension"
        android:left="dimension" />
</transition>
 
- एलिमेंट:
 
- 
  <transition> 
    - ज़रूरी है. यह रूट एलिमेंट होना चाहिए. एक या ज़्यादा 
<item> एलिमेंट शामिल हैं.
      विशेषताएं:
      
        xmlns:android 
          - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
          
"http://schemas.android.com/apk/res/android".
       
     
  <item> 
    - ड्रॉ करने लायक ट्रांज़िशन के हिस्से के तौर पर इस्तेमाल किए जाने वाले ड्रॉएबल के बारे में बताता है.
<transition> एलिमेंट का चाइल्ड होना चाहिए. चाइल्ड <bitmap> स्वीकार किया जाता है
एलिमेंट.
      विशेषताएं:
      
        android:drawable 
          - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का रेफ़रंस
संसाधन.
 
        android:id 
          - संसाधन आईडी. ड्रॉएबल के लिए यूनीक संसाधन आईडी. नया संसाधन बनाने के लिए
इस आइटम का आईडी, इस फ़ॉर्म का इस्तेमाल करें:
"@+id/name". प्लस का चिह्न संकेत देता है कि इसे एक नए नाम के रूप में बनाया गया है
आईडी. इस आइडेंटिफ़ायर का इस्तेमाल इन कामों के लिए किया जा सकता है
ड्रॉएबल को View.findViewById() या Activity.findViewById() की मदद से वापस पाएं और उसमें बदलाव करें. 
        android:top 
          - पूरी संख्या. पिक्सल में ऊपर का ऑफ़सेट.
 
        android:right 
          - पूरी संख्या. पिक्सल में दायां ऑफ़सेट.
 
        android:bottom 
          - पूरी संख्या. नीचे का ऑफ़सेट पिक्सल में.
 
        android:left 
          - पूरी संख्या. पिक्सल में बायां ऑफ़सेट.
 
      
     
  
- उदाहरण:
 
- एक्सएमएल फ़ाइल 
res/drawable/transition.xml पर सेव की गई:
<?xml version="1.0" encoding="utf-8"?>
<transition xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/on" />
    <item android:drawable="@drawable/off" />
</transition>
यह लेआउट एक्सएमएल किसी व्यू पर ड्रॉएबल लागू करता है:
<ImageButton
    android:id="@+id/button"
    android:layout_height="wrap_content"
    android:layout_width="wrap_content"
    android:src="@drawable/transition" />
और नीचे दिया गया कोड पहले आइटम से दूसरे आइटम में 500 मि॰से॰ का ट्रांज़िशन करता है:
Kotlin
val button: ImageButton = findViewById(R.id.button)
val drawable: Drawable = button.drawable
if (drawable is TransitionDrawable) {
    drawable.startTransition(500)
}
Java
ImageButton button = (ImageButton) findViewById(R.id.button);
Drawable drawable = button.getDrawable();
if (drawable instanceof TransitionDrawable) {
    ((TransitionDrawable) drawable).startTransition(500);
}
 
  
- यह भी देखें:
 
- 
 
इनसेट ड्रॉएबल
एक्सएमएल में तय किया गया ड्रॉबल, जिसमें तय की गई दूरी से ड्रॉ करने लायक कोई दूसरा एलिमेंट शामिल होता है. यह काम का है
जब किसी व्यू के लिए ऐसा बैकग्राउंड चाहिए जो व्यू की असल सीमाओं से कम हो.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
InsetDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<inset
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/drawable_resource"
    android:insetTop="dimension"
    android:insetRight="dimension"
    android:insetBottom="dimension"
    android:insetLeft="dimension" />
 
- एलिमेंट:
 
- 
  <inset> 
  - ज़रूरी है. इनसेट ड्रॉएबल के बारे में बताता है. यह रूट एलिमेंट होना चाहिए.
    
विशेषताएं:
    
      xmlns:android 
        - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
        
"http://schemas.android.com/apk/res/android".
       android:drawable 
        - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का संदर्भ
किया जा सकता है.
 
      android:insetTop 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, सबसे ऊपर मौजूद इनसेट.
 
      android:insetRight 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर सही इनसेट.
 
      android:insetBottom 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, सबसे नीचे मौजूद इनसेट.
 
      android:insetLeft 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर बायां इनसेट.
 
    
   
 
- उदाहरण:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<inset xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/background"
    android:insetTop="10dp"
    android:insetLeft="10dp" />
 
- यह भी देखें:
 
- 
 
ड्रॉ करने लायक क्लिप
एक्सएमएल में एक ऐसा ड्रॉबल तय किया गया है जो इस ड्रॉएबल के मौजूदा लेवल के आधार पर, किसी दूसरे ड्रॉबल को क्लिप करता है. आपने लोगों तक पहुंचाया मुफ़्त में
यह कंट्रोल किया जा सकता है कि लेवल के हिसाब से, ड्रॉ करने लायक चाइल्ड कार्ड की चौड़ाई और ऊंचाई कितनी होगी
इसे अपने कंटेनर में कहां रखा जाए, इसे कंट्रोल करने के लिए गुरुत्वाकर्षण के रूप में इस्तेमाल किया जाता है. अक्सर लागू करने के लिए इस्तेमाल किए जाते हैं
जैसे कि प्रोग्रेस बार.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
ClipDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<clip
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/drawable_resource"
    android:clipOrientation=["horizontal" | "vertical"]
    android:gravity=["top" | "bottom" | "left" | "right" | "center_vertical" |
                     "fill_vertical" | "center_horizontal" | "fill_horizontal" |
                     "center" | "fill" | "clip_vertical" | "clip_horizontal"] />
 
- एलिमेंट:
 
- 
  <clip> 
  - ज़रूरी है. ड्रॉ की जा सकने वाली क्लिप के बारे में बताता है. यह रूट एलिमेंट होना चाहिए.
    
विशेषताएं:
    
      xmlns:android 
        - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
        
"http://schemas.android.com/apk/res/android".
       android:drawable 
        - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का रेफ़रंस
संसाधन होना चाहिए.
 
      android:clipOrientation 
        - कीवर्ड. क्लिप का ओरिएंटेशन.
          
इनमें से कोई एक कॉन्सटैंट वैल्यू होनी चाहिए:
| वैल्यू | ब्यौरा | 
horizontal | 
ड्रॉ करने लायक हिस्से को हॉरिज़ॉन्टल तौर पर क्लिप करें. | 
vertical | 
ड्रॉ करने लायक हिस्से को वर्टिकल तौर पर क्लिप करें. | 
         
      android:gravity 
        - कीवर्ड. बताता है कि ड्रॉ किए जा सकने वाले वीडियो में कहां क्लिप करनी है.
          
इनमें से एक या एक से ज़्यादा कॉन्सटेंट वैल्यू होनी चाहिए, जिन्हें | से अलग किया गया हो:
| वैल्यू | ब्यौरा | 
top | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के ऊपर रखें. जब clipOrientation "vertical" होता है, तो क्लिप ड्रॉ करने लायक के निचले हिस्से में होती है. | 
bottom | 
ऑब्जेक्ट को उसके कंटेनर के नीचे रखें, उसका आकार बदले बिना. जब clipOrientation की वैल्यू "vertical" होती है, तब ड्रॉ की जा सकने वाली फ़ाइल के सबसे ऊपर क्लिपिंग की जाती है. | 
left | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना उसके कंटेनर के बाएं किनारे पर रखें. यह है
डिफ़ॉल्ट. जब clipOrientation "horizontal" होता है, तो क्लिपिंग
ड्रॉ करने लायक है. | 
right | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना उसके कंटेनर के दाएं किनारे पर रखें. जब clipOrientation "horizontal" होता है, तो क्लिपिंग इसके बाईं ओर होती है
ड्रॉ करने लायक है. | 
center_vertical | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के वर्टिकल सेंटर में रखें. क्लिपिंग व्यवहार करती है
ठीक वैसे ही जैसे गुरुत्वाकर्षण "center" होने पर होता है. | 
fill_vertical | 
अगर ज़रूरी हो, तो ऑब्जेक्ट का वर्टिकल साइज़ बढ़ाएं, ताकि यह अपने कंटेनर को पूरी तरह से भर सके. जब clipOrientation "vertical" होता है, तो कोई क्लिपिंग नहीं होती, क्योंकि ड्रॉ करने योग्य
वर्टिकल स्पेस (जब तक ड्रॉ करने लायक लेवल 0 न हो, इस स्थिति में यह नहीं दिखेगा). | 
center_horizontal | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के हॉरिज़ॉन्टल सेंटर में रखें.
क्लिपिंग भी उसी तरह काम करती है जैसे गुरुत्वाकर्षण "center" होने पर किया जाता है. | 
fill_horizontal | 
अगर ज़रूरत हो, तो ऑब्जेक्ट का हॉरिज़ॉन्टल साइज़ बढ़ाएं, ताकि यह अपने कंटेनर को पूरी तरह से भर सके. टास्क कब शुरू होगा
clipOrientation "horizontal" है, कोई क्लिपिंग नहीं होती, क्योंकि ड्रॉ करने योग्य
हॉरिज़ॉन्टल स्पेस (जब तक ड्रॉ करने लायक लेवल 0 न हो, इस स्थिति में यह नहीं दिखेगा).
 | 
center | 
ऑब्जेक्ट को उसके कंटेनर के बीच में वर्टिकल और हॉरिज़ॉन्टल, दोनों ऐक्सिस में रखें, न कि
उसका आकार बदल रहा है. जब clipOrientation "horizontal" होता है, तो क्लिपिंग बाईं और दाईं ओर होती है. जब clipOrientation "vertical" होता है, तो ऊपर और नीचे क्लिपिंग होती है. | 
fill | 
अगर ज़रूरत हो, तो ऑब्जेक्ट का हॉरिज़ॉन्टल और वर्टिकल साइज़ बड़ा करें, ताकि यह ऑब्जेक्ट को पूरी तरह से भर सके
कंटेनर. कोई क्लिपिंग नहीं होती क्योंकि ड्रॉ करने योग्य
हॉरिज़ॉन्टल और वर्टिकल स्पेस (अगर ड्रॉ करने लायक लेवल 0 न हो, इस मामले में यह
दिखाई देता है). | 
clip_vertical | 
बच्चे के ऊपरी और/या निचले किनारों को क्लिप करने के लिए सेट किया जा सकने वाला अन्य विकल्प
उसके कंटेनर की सीमाएं शामिल होती हैं. यह क्लिप लंबवत गुरुत्वाकर्षण पर आधारित है: शीर्ष गुरुत्वाकर्षण क्लिप
निचला किनारा, निचला गुरुत्वाकर्षण ऊपरी किनारे को क्लिप करता है, और कोई भी दोनों किनारों को क्लिप नहीं करता है.
 | 
clip_horizontal | 
दूसरा विकल्प, जिसे इस तरह सेट किया जा सकता है कि बच्चे के बाएं और/या दाएं किनारे क्लिप किए जाएं
उसके कंटेनर की सीमाएं शामिल होती हैं. यह क्लिप हॉरिज़ॉन्टल गुरुत्वाकर्षण पर आधारित है: बायां गुरुत्वाकर्षण क्लिप
दाईं ओर से, दाईं ओर का गुरुत्वाकर्षण, बाएं किनारे को क्लिप करता है, और कोई भी दोनों किनारों को क्लिप नहीं करता है.
 | 
 
    
   
  
- उदाहरण:
 
- एक्सएमएल फ़ाइल 
res/drawable/clip.xml पर सेव की गई:
<?xml version="1.0" encoding="utf-8"?>
<clip xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/android"
    android:clipOrientation="horizontal"
    android:gravity="left" />
    व्यू में बनाई गई क्लिप को इस लेआउट एक्सएमएल में लागू किया जाता है:
<ImageView
    android:id="@+id/image"
    android:src="@drawable/clip"
    android:layout_height="wrap_content"
    android:layout_width="wrap_content" />
    नीचे दिया गया कोड ड्रॉ करने लायक बन जाता है और क्लिपिंग की मात्रा बढ़ाकर
इमेज को धीरे-धीरे दिखाएँ:
Kotlin
val imageview: ImageView = findViewById(R.id.image)
val drawable: Drawable = imageview.background
if (drawable is ClipDrawable) {
    drawable.level = drawable.level + 1000
}
Java
ImageView imageview = (ImageView) findViewById(R.id.image);
Drawable drawable = imageview.getBackground();
if (drawable instanceof ClipDrawable) {
    ((ClipDrawable)drawable).setLevel(drawable.getLevel() + 1000);
}
 
लेवल बढ़ाने से क्लिपिंग कम हो जाती है और इमेज धीरे-धीरे दिखती है. यह रहा
7,000 के लेवल पर:
ध्यान दें: डिफ़ॉल्ट लेवल 0 है, जो पूरी तरह से क्लिप किया गया है, ताकि इमेज
नहीं दिखता. जब लेवल 10,000 का होता है, तब इमेज क्लिप नहीं होती और पूरी तरह से दिखती है.
  
- यह भी देखें:
 
- 
 
ड्रॉ करने लायक स्केल
एक्सएमएल में तय किया गया ड्रॉबल, जो किसी दूसरे ड्रॉएबल का साइज़ उसके मौजूदा साइज़ के आधार पर बदलता है
लेवल.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
ScaleDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<scale
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/drawable_resource"
    android:scaleGravity=["top" | "bottom" | "left" | "right" | "center_vertical" |
                          "fill_vertical" | "center_horizontal" | "fill_horizontal" |
                          "center" | "fill" | "clip_vertical" | "clip_horizontal"]
    android:scaleHeight="percentage"
    android:scaleWidth="percentage" />
 
- एलिमेंट:
 
- 
  <scale> 
  - ज़रूरी है. ड्रॉएबल स्केल के बारे में बताता है. यह रूट एलिमेंट होना चाहिए.
    
विशेषताएं:
    
      xmlns:android 
        - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
        
"http://schemas.android.com/apk/res/android".
       android:drawable 
        - ड्रॉ करने लायक संसाधन. ज़रूरी है. ड्रॉएबल का रेफ़रंस
संसाधन.
 
      android:scaleGravity 
        - कीवर्ड. स्केलिंग के बाद गुरुत्वाकर्षण स्थिति तय करता है.
          
इनमें से एक या एक से ज़्यादा कॉन्सटेंट वैल्यू होनी चाहिए, जिन्हें | से अलग किया गया हो:
| वैल्यू | ब्यौरा | 
top | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के ऊपर रखें. | 
bottom | 
ऑब्जेक्ट को उसके कंटेनर के नीचे रखें, उसका आकार बदले बिना.  | 
left | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना उसके कंटेनर के बाएं किनारे पर रखें. यह है
डिफ़ॉल्ट. | 
right | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना उसके कंटेनर के दाएं किनारे पर रखें.  | 
center_vertical | 
ऑब्जेक्ट को उसके साइज़ में बदलाव किए बिना, उसके कंटेनर के वर्टिकल सेंटर में रखें.  | 
fill_vertical | 
अगर ज़रूरी हो, तो ऑब्जेक्ट का वर्टिकल साइज़ बढ़ाएं, ताकि यह अपने कंटेनर को पूरी तरह से भर सके.  | 
center_horizontal | 
ऑब्जेक्ट को उसके आकार में बदलाव किए बिना, उसके कंटेनर के हॉरिज़ॉन्टल सेंटर में रखें.  | 
fill_horizontal | 
अगर ज़रूरत हो, तो ऑब्जेक्ट का हॉरिज़ॉन्टल साइज़ बढ़ाएं, ताकि यह अपने कंटेनर को पूरी तरह से भर सके.
 | 
center | 
ऑब्जेक्ट को उसके कंटेनर के बीच में वर्टिकल और हॉरिज़ॉन्टल, दोनों ऐक्सिस में रखें, न कि
उसका आकार बदल रहा है.  | 
fill | 
अगर ज़रूरत हो, तो ऑब्जेक्ट का हॉरिज़ॉन्टल और वर्टिकल साइज़ बड़ा करें, ताकि यह ऑब्जेक्ट को पूरी तरह से भर सके
कंटेनर.  | 
clip_vertical | 
बच्चे के ऊपरी और/या निचले किनारों को क्लिप करने के लिए सेट किया जा सकने वाला अन्य विकल्प
उसके कंटेनर की सीमाएं शामिल होती हैं. यह क्लिप लंबवत गुरुत्वाकर्षण पर आधारित है: शीर्ष गुरुत्वाकर्षण क्लिप
निचला किनारा, निचला गुरुत्वाकर्षण ऊपरी किनारे को क्लिप करता है, और कोई भी दोनों किनारों को क्लिप नहीं करता है.
 | 
clip_horizontal | 
अतिरिक्त विकल्प जिसे बच्चे के बाएं और/या दाएं किनारों को क्लिप करने के लिए सेट किया जा सकता है
उसके कंटेनर की सीमाएं शामिल होती हैं. यह क्लिप हॉरिज़ॉन्टल गुरुत्वाकर्षण पर आधारित है: बायां गुरुत्वाकर्षण क्लिप
दाईं ओर से, दाईं ओर का गुरुत्वाकर्षण, बाएं किनारे को क्लिप करता है, और कोई भी दोनों किनारों को क्लिप नहीं करता है.
 | 
 
      android:scaleHeight 
        - प्रतिशत. स्केल की ऊंचाई, जिसे ड्रॉएबल के प्रतिशत के तौर पर दिखाया जाता है
सीमित. वैल्यू का फ़ॉर्मैट XX% है, जैसे कि 100% या 12.5%.
 
      android:scaleWidth 
        - प्रतिशत. स्केल की चौड़ाई, जिसे ड्रॉएबल के प्रतिशत के तौर पर दिखाया जाता है
सीमित. वैल्यू का फ़ॉर्मैट XX% है, जैसे कि 100% या 12.5%.
 
    
   
 
- उदाहरण:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<scale xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/logo"
    android:scaleGravity="center_vertical|center_horizontal"
    android:scaleHeight="80%"
    android:scaleWidth="80%" />
 
- यह भी देखें:
 
- 
 
आकार ड्रॉ करने योग्य
यह एक सामान्य आकार है, जिसके बारे में एक्सएमएल में बताया गया है.
- फ़ाइल की जगह:
 
res/drawable/filename.xml
फ़ाइल का नाम, रिसॉर्स आईडी है 
- कंपाइल किए गए संसाधन डेटा टाइप:
 
GradientDrawable के लिए रिसॉर्स पॉइंटर 
- संसाधन का रेफ़रंस:
 
-  अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
Java में: 
R.drawable.filename
एक्सएमएल में: @[package:]drawable/filename
 
- सिंटैक्स:
 
- 
<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape=["rectangle" | "oval" | "line" | "ring"] >
    <corners
        android:radius="integer"
        android:topLeftRadius="integer"
        android:topRightRadius="integer"
        android:bottomLeftRadius="integer"
        android:bottomRightRadius="integer" />
    <gradient
        android:angle="integer"
        android:centerX="float"
        android:centerY="float"
        android:centerColor="integer"
        android:endColor="color"
        android:gradientRadius="integer"
        android:startColor="color"
        android:type=["linear" | "radial" | "sweep"]
        android:useLevel=["true" | "false"] />
    <padding
        android:left="integer"
        android:top="integer"
        android:right="integer"
        android:bottom="integer" />
    <size
        android:width="integer"
        android:height="integer" />
    <solid
        android:color="color" />
    <stroke
        android:width="integer"
        android:color="color"
        android:dashWidth="integer"
        android:dashGap="integer" />
</shape>
 
- एलिमेंट:
 
- 
  <shape> 
    - ज़रूरी है. आकृति ड्रॉ करने योग्य. यह रूट एलिमेंट होना चाहिए.
      
विशेषताएं:
      
        xmlns:android 
          - स्ट्रिंग. ज़रूरी है. एक्सएमएल नेमस्पेस तय करता है, जिसे
          
"http://schemas.android.com/apk/res/android".
         android:shape 
        - कीवर्ड. आकार का टाइप बताता है. मान्य मान हैं:
          
            | वैल्यू | ब्यौरा | 
            "rectangle" | 
                एक रेक्टैंगल, जो मौजूदा व्यू को भर देता है. यह डिफ़ॉल्ट आकार है. | 
            "oval" | 
                एक अंडाकार आकार, जो शामिल व्यू के डाइमेंशन के मुताबिक होता है. | 
            "line" | 
                एक हॉरिज़ॉन्टल लाइन, जो कंटेनमेंट व्यू की चौड़ाई में फैली होती है. यह
                आकार की चौड़ाई को परिभाषित करने के लिए <stroke> एलिमेंट की ज़रूरत होती है
                लाइन. | 
            "ring" | 
                रिंग का आकार. | 
          
         
      
      इन एट्रिब्यूट का इस्तेमाल सिर्फ़ तब किया जाता है, जब android:shape="ring":
      
        android:innerRadius 
        - डाइमेंशन. 
रिंग के अंदरूनी हिस्से (बीच में छेद) को डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर.
 
        android:innerRadiusRatio 
        - फ़्लोट. अंदर का रेडियस
रिंग का एक हिस्सा है, जिसे रिंग की चौड़ाई के अनुपात में दिखाया जाता है. उदाहरण के लिए, अगर 
android:innerRadiusRatio="5" है, तो अंदरूनी रेडियस रिंग की चौड़ाई को 5 से भाग देने पर मिली वैल्यू के बराबर होगा. यह
मान को android:innerRadius से बदल दिया गया है. डिफ़ॉल्ट वैल्यू 9 है. 
        android:thickness 
        - डाइमेंशन. इसकी मोटाई
रिंग, डाइमेंशन मान या डाइमेंशन संसाधन के तौर पर.
 
        android:thicknessRatio 
        - फ़्लोट. रिंग की मोटाई
रिंग की चौड़ाई के अनुपात के तौर पर दिखाया जाता है. उदाहरण के लिए, अगर 
android:thicknessRatio="2", तो
मोटाई, रिंग की चौड़ाई को 2 से भाग देने पर मिलती है. इस वैल्यू को android:innerRadius से बदल दिया गया है. डिफ़ॉल्ट वैल्यू तीन है. 
        android:useLevel 
        - बूलियन. सही है, अगर इसका इस्तेमाल इस तौर पर किया जाता है
LevelListDrawable. आम तौर पर, यह जानकारी गलत होती है,
          या फिर हो सकता है कि आपका आकार न दिखे. 
      
   <corners> 
    - आकार के लिए गोल कोने बनाता है. यह सिर्फ़ तब लागू होता है, जब आकार कोई रेक्टैंगल होता है.
      
विशेषताएं:
      
        android:radius 
        - डाइमेंशन. सभी कोनों का दायरा, डाइमेंशन वैल्यू या डाइमेंशन संसाधन के तौर पर. यह हर एक के लिए बदल जाता है
को फ़ॉलो करें.
 
        android:topLeftRadius 
        - डाइमेंशन. सबसे ऊपर बाएं कोने का रेडियस, डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर.
 
        android:topRightRadius 
        - डाइमेंशन. सबसे ऊपर दाएं कोने का दायरा, डाइमेंशन वैल्यू या डाइमेंशन संसाधन के तौर पर.
 
        android:bottomLeftRadius 
        - डाइमेंशन. सबसे नीचे बाएं कोने का दायरा, डाइमेंशन वैल्यू या डाइमेंशन संसाधन के तौर पर.
 
        android:bottomRightRadius 
        - डाइमेंशन. सबसे नीचे दाएं कोने का दायरा, डाइमेंशन वैल्यू या डाइमेंशन संसाधन के तौर पर.
 
      
      ध्यान दें: शुरुआत में हर कोने के लिए एक कोने की जानकारी दी जानी चाहिए
रेडियस 1 से ज़्यादा है, तो कोई भी कोने गोल नहीं होंगे. अगर आपको कुछ खास कोने चाहिए
को राउंड नहीं किया जाना चाहिए, तो इसका मतलब है कि डिफ़ॉल्ट कोने को सेट करने के लिए android:radius का इस्तेमाल करें
रेडियस 1 से ज़्यादा है और फिर हर कोने को खास मानों से बदल देता है
चाहते हैं, तो 0 ("0dp") दें, जहां आपको गोल कोने नहीं चाहिए.
     
  <gradient> 
    - आकार के लिए ग्रेडिएंट रंग तय करता है.
      
विशेषताएं:
      
        android:angle 
        - पूरी संख्या. ग्रेडिएंट के लिए कोण, डिग्री में. 0 को बाएं से दाएं, 90 को
नीचे से ऊपर. यह 45 का गुणांक होना चाहिए. डिफ़ॉल्ट वैल्यू 0 होती है.
 
        android:centerX 
        - फ़्लोट. ग्रेडिएंट के केंद्र के लिए सापेक्ष X-स्थिति (0 - 1.0).
 
        android:centerY 
        - फ़्लोट. ग्रेडिएंट के केंद्र के लिए सापेक्ष Y-स्थिति (0 - 1.0).
 
        android:centerColor 
        - रंग. यह शुरुआती और आखिरी रंगों के बीच आने वाला वैकल्पिक रंग होता है.
हेक्साडेसिमल मान या रंग संसाधन.
 
        android:endColor 
        - रंग. आखिरी रंग, हेक्साडेसिमल के रूप में
वैल्यू या रंग से जुड़े संसाधन शामिल करें.
 
        android:gradientRadius 
        - फ़्लोट. ग्रेडिएंट का दायरा. यह ऑफ़र सिर्फ़ 
android:type="radial" पर लागू होगा. 
        android:startColor 
        - रंग. शुरुआती रंग, हेक्साडेसिमल के रूप में
वैल्यू या रंग से जुड़े संसाधन शामिल करें.
 
        android:type 
        - कीवर्ड. लागू किए जाने वाले ग्रेडिएंट पैटर्न का प्रकार. मान्य मान हैं:
          
            | वैल्यू | ब्यौरा | 
            "linear" | 
                एक लीनियर ग्रेडिएंट. यह डिफ़ॉल्ट विकल्प है. | 
            "radial" | 
                रेडियल ग्रेडिएंट. शुरुआती रंग, बीच का रंग होता है. | 
            "sweep" | 
                लाइन का स्वीप ग्रेडिएंट.  | 
          
         
        android:useLevel 
        - बूलियन. अगर इसका इस्तेमाल 
LevelListDrawable के तौर पर किया जाता है, तो वैल्यू 'सही' होगी. 
      
     
  <padding> 
    - शामिल किए गए व्यू एलिमेंट पर लागू करने के लिए पैडिंग. यह व्यू की स्थिति को पैड करता है
सामग्री होती है, आकार नहीं.
      
विशेषताएं:
      
        android:left 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर बाईं ओर की पैडिंग.
 
        android:top 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, टॉप पैडिंग.
 
        android:right 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर दाईं ओर की पैडिंग.
 
        android:bottom 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, सबसे नीचे की पैडिंग.
 
      
     
  <size> 
    - आकार का साइज़.
      
विशेषताएं:
      
        android:height 
        - डाइमेंशन. आकार की ऊंचाई, डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर.
 
        android:width 
        - डाइमेंशन. आकार की चौड़ाई, डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर.
 
      
      ध्यान दें: डिफ़ॉल्ट रूप से, आकार कंटेनर के साइज़ के मुताबिक होता है
यहां बताए गए डाइमेंशन के हिसाब से रेवेन्यू जनरेट होता है. जब ImageView में आकृति का इस्तेमाल किया जाता है, तो android:scaleType को "center" पर सेट करके स्केलिंग को सीमित किया जा सकता है.
     
  <solid> 
    - आकार भरने के लिए ठोस रंग.
      
विशेषताएं:
      
        android:color 
        - रंग. आकृति पर लागू किया जाने वाला रंग, हेक्साडेसिमल के रूप में
वैल्यू या रंग से जुड़े संसाधन शामिल करें.
 
      
     
  <stroke> 
    - आकार के लिए स्ट्रोक लाइन.
      
विशेषताएं:
      
        android:width 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर लाइन की मोटाई.
 
        android:color 
        - रंग. लाइन का रंग, जिससे
हेक्साडेसिमल मान या रंग संसाधन.
 
        android:dashGap 
        - डाइमेंशन. डाइमेंशन वैल्यू या डाइमेंशन रिसॉर्स के तौर पर, लाइन डैश के बीच की दूरी. सिर्फ़ तब मान्य होता है, जब 
android:dashWidth सेट हो. 
        android:dashWidth 
        - डाइमेंशन. हर डैश लाइन का साइज़, डाइमेंशन वैल्यू या डाइमेंशन संसाधन के तौर पर. सिर्फ़ तब मान्य होता है, जब 
android:dashGap सेट हो. 
      
     
  
- उदाहरण:
 
- एक्सएमएल फ़ाइल 
res/drawable/gradient_box.xml पर सेव की गई:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <gradient
        android:startColor="#FFFF0000"
        android:endColor="#80FF00FF"
        android:angle="45"/>
    <padding android:left="7dp"
        android:top="7dp"
        android:right="7dp"
        android:bottom="7dp" />
    <corners android:radius="8dp" />
</shape>
    यह लेआउट एक्सएमएल, व्यू में बनाए जा सकने वाले आकार को लागू करता है:
<TextView
    android:background="@drawable/gradient_box"
    android:layout_height="wrap_content"
    android:layout_width="wrap_content" />
    यह ऐप्लिकेशन कोड आकार बनाने लायक बन जाता है और उसे किसी व्यू पर लागू करता है:
Kotlin
val shape: Drawable? = getDrawable(resources, R.drawable.gradient_box, getTheme())
val tv: TextView = findViewById(R.id.textview)
tv.background = shape
Java
Resources res = getResources();
Drawable shape = ResourcesCompat.getDrawable(res, R.drawable.gradient_box, getTheme());
TextView tv = (TextView)findViewById(R.id.textview);
tv.setBackground(shape);
 
  
- यह भी देखें:
 
-