अपने ऐप्लिकेशन में स्टाइल लागू करने के तीन तरीके हैं:
- मौजूदा कॉम्पोनेंट पर सीधे तौर पर स्टाइल लागू करना. इसके लिए, कॉम्पोनेंट में
Styleपैरामीटर होना चाहिए. - लेआउट
कंपोज़ेबल पर
Modifier.styleableकी मदद से स्टाइल लागू करना. इसके लिए, कंपोज़ेबल मेंStyleपैरामीटर नहीं होना चाहिए. - अपने कस्टम डिज़ाइन सिस्टम में,
Modifier.styleable{}का इस्तेमाल करना और अपने कॉम्पोनेंट पर स्टाइल पैरामीटर दिखाना.
स्टाइल पर उपलब्ध प्रॉपर्टी
स्टाइल, मॉडिफ़ायर की कई प्रॉपर्टी के साथ काम करती हैं. हालांकि, स्टाइल की मदद से मॉडिफ़ायर की सभी प्रॉपर्टी को कॉपी नहीं किया जा सकता. कुछ खास तरह के व्यवहार के लिए, मॉडिफ़ायर की ज़रूरत होती है. जैसे, इंटरैक्शन, कस्टम ड्राइंग या प्रॉपर्टी को स्टैक करना.
| ग्रुपिंग | प्रॉपर्टी | चाइल्ड कॉम्पोनेंट को इनहेरिट की गई प्रॉपर्टी |
|---|---|---|
| लेआउट और साइज़िंग | ||
| पैडिंग (जगह) | contentPadding (अंदर की ओर) और externalPadding (बाहर की ओर). ये प्रॉपर्टी, डायरेक्शनल, हॉरिज़ॉन्टल, वर्टिकल, और सभी साइड वाले वैरिएंट में उपलब्ध हैं. |
नहीं |
| डाइमेंशन | fillWidth/Height/Size() और width, height, और size (Dp, DpSize, या Float फ़्रैक्शन के साथ काम करती हैं). |
नहीं |
| स्टिकर दिखने की जगह | left/top/right/bottom ऑफ़सेट. |
नहीं |
| विज़ुअल अपीयरेंस | ||
| पानी भरें | background और foreground (ये Color या Brush के साथ काम करती हैं). |
नहीं |
| बॉर्डर | borderWidth, borderColor, और borderBrush. |
नहीं |
| आकार | shape |
नहीं. हालांकि, इसका इस्तेमाल अन्य प्रॉपर्टी के साथ किया जाता है. clip और border में, तय किए गए इस आकार का इस्तेमाल किया जाता है. |
| परछाई | dropShadow, innerShadow |
नहीं |
| ट्रांसफ़ॉर्मेशन | ||
| ग्राफ़िक्स लेयर की जगह में बदलाव | translationX, translationY, scaleX/Y, rotationX/Y/Z |
नहीं |
| कंट्रोल | alpha, zIndex (स्टैकिंग ऑर्डर), और transformOrigin (पिवट पॉइंट) |
नहीं |
| टाइपोग्राफ़ी | ||
| स्टाइल | textStyle, fontSize, fontWeight, fontStyle, और fontFamily |
हां |
| वर्णक्रम | contentColor और contentBrush. इसका इस्तेमाल, आइकॉन की स्टाइलिंग के लिए भी किया जाता है. |
हां |
| पैराग्राफ़ | lineHeight, letterSpacing, textAlign, textDirection, lineBreak, और hyphens. |
हां |
| सजावट | textDecoration, textIndent, और baselineShift. |
हां |
स्टाइल पैरामीटर वाले कॉम्पोनेंट पर सीधे तौर पर स्टाइल लागू करना
जिन कॉम्पोनेंट में Style पैरामीटर होता है उनकी स्टाइलिंग सेट की जा सकती है:
BaseButton( onClick = { }, style = { } ) { BaseText("Click me") }
स्टाइल लैम्डा में, कई प्रॉपर्टी सेट की जा सकती हैं. जैसे, externalPadding या background:
BaseButton( onClick = { }, style = { background(Color.Blue) } ) { BaseText("Click me") }
काम करने वाली प्रॉपर्टी की पूरी सूची देखने के लिए, स्टाइल पर उपलब्ध प्रॉपर्टी देखें.
मौजूदा पैरामीटर वाले कॉम्पोनेंट के लिए, मॉडिफ़ायर का इस्तेमाल करके स्टाइल लागू करना
जिन कॉम्पोनेंट में स्टाइल पैरामीटर नहीं होता है उन पर भी styleable मॉडिफ़ायर की मदद से स्टाइल लागू की जा सकती हैं. कस्टम कॉम्पोनेंट डेवलप करते समय भी यह तरीका काम आता है.
Row( modifier = Modifier.styleable { } ) { BaseText("Content") }
style पैरामीटर की तरह, लैम्डा में background या padding जैसी प्रॉपर्टी शामिल की जा सकती हैं.
Row( modifier = Modifier.styleable { background(Color.Blue) } ) { BaseText("Content") }
चेन किए गए एक से ज़्यादा Modifier.styleable मॉडिफ़ायर, लागू किए गए कंपोज़ेबल पर इनहेरिट नहीं की गई प्रॉपर्टी के साथ जुड़ जाते हैं. इनका व्यवहार, एक ही प्रॉपर्टी को तय करने वाले एक से ज़्यादा मॉडिफ़ायर की तरह होता है. इनहेरिट की गई प्रॉपर्टी के लिए, इन्हें ओवरराइड किया जाता है. साथ ही, चेन में मौजूद आखिरी styleable मॉडिफ़ायर, वैल्यू सेट करता है.
Modifier.styleable का इस्तेमाल करते समय, StyleState बनाया और उपलब्ध कराया जा सकता है. इसका इस्तेमाल, मॉडिफ़ायर के साथ किया जाता है, ताकि स्टेट के आधार पर स्टाइलिंग लागू की जा सके. ज़्यादा जानकारी के लिए, स्टाइल के साथ स्टेट और ऐनिमेशन देखें.
स्टैंडअलोन स्टाइल तय करना
रीयूज़ेबिलिटी के लिए, स्टैंडअलोन स्टाइल तय की जा सकती है:
val style = Style { background(Color.Blue) }
इसके बाद, तय की गई उस स्टाइल को कंपोज़ेबल के स्टाइल पैरामीटर में या Modifier.styleable के साथ पास किया जा सकता है. Modifier.styleable का इस्तेमाल करते समय, StyleState ऑब्जेक्ट भी बनाना होगा. StyleState के बारे में ज़्यादा जानकारी, स्टाइल के साथ स्टेट और
ऐनिमेशन दस्तावेज़ में दी गई है.
यहां दिए गए उदाहरण में, स्टाइल को सीधे तौर पर कॉम्पोनेंट के इन-बिल्ट पैरामीटर या Modifier.styleable की मदद से लागू करने का तरीका बताया गया है:
val style = Style { background(Color.Blue) } // built in parameter BaseButton(onClick = { }, style = style) { BaseText("Button") } // modifier styleable val styleState = remember { MutableStyleState(null) } Column( Modifier.styleable(styleState, style) ) { BaseText("Column content") }
उस स्टाइल को एक से ज़्यादा कॉम्पोनेंट में भी पास किया जा सकता है:
val style = Style { background(Color.Blue) } // built in parameter BaseButton(onClick = { }, style = style) { BaseText("Button") } BaseText("Different text that uses the same style parameter", style = style) // modifier styleable val columnStyleState = remember { MutableStyleState(null) } Column( Modifier.styleable(columnStyleState, style) ) { BaseText("Column") } val rowStyleState = remember { MutableStyleState(null) } Row( Modifier.styleable(rowStyleState, style) ) { BaseText("Row") }
एक से ज़्यादा स्टाइल प्रॉपर्टी जोड़ना
हर लाइन में अलग-अलग प्रॉपर्टी सेट करके, एक से ज़्यादा स्टाइल प्रॉपर्टी जोड़ी जा सकती हैं:
BaseButton( onClick = { }, style = { background(Color.Blue) contentPaddingStart(16.dp) } ) { BaseText("Button") }
मॉडिफ़ायर पर आधारित स्टाइलिंग के उलट, स्टाइल में मौजूद प्रॉपर्टी जुड़ती नहीं हैं. स्टाइल, एक स्टाइल ब्लॉक में मौजूद प्रॉपर्टी की सूची में सेट की गई आखिरी वैल्यू लेती हैं. यहां दिए गए उदाहरण में, बैकग्राउंड को दो बार सेट किया गया है. इसलिए, TealColor को बैकग्राउंड के तौर पर लागू किया गया है. पैडिंग के लिए, contentPaddingTop टॉप
पैडिंग को ओवरराइड करता है जिसे contentPadding से सेट किया गया है और वैल्यू को जोड़ता नहीं है.
BaseButton( style = { background(Color.Red) // Background of Red is now overridden with TealColor instead background(TealColor) // All directions of padding are set to 64.dp (top, start, end, bottom) contentPadding(64.dp) // Top padding is now set to 16.dp, all other paddings remain at 64.dp contentPaddingTop(16.dp) }, onClick = { // } ) { BaseText("Click me!") }
contentPadding ओवरराइड वाला बटन.एक से ज़्यादा स्टाइल ऑब्जेक्ट मर्ज करना
एक से ज़्यादा स्टाइल ऑब्जेक्ट बनाए जा सकते हैं और उन्हें अपने कंपोज़ेबल के स्टाइल पैरामीटर में पास किया जा सकता है.
val style1 = Style { background(TealColor) } val style2 = Style { contentPaddingTop(16.dp) } BaseButton( style = style1 then style2, onClick = { }, ) { BaseText("Click me!") }
contentPaddingTop सेट वाला बटन.जब एक से ज़्यादा स्टाइल, एक ही प्रॉपर्टी तय करती हैं, तो सेट की गई आखिरी प्रॉपर्टी को चुना जाता है. स्टाइल में प्रॉपर्टी जुड़ती नहीं हैं. इसलिए, पास की गई आखिरी
पैडिंग, शुरुआती
contentPadding से सेट की गई contentPaddingHorizontal को ओवरराइड करती है. इसके अलावा, पास किया गया आखिरी बैकग्राउंड कलर, शुरुआती स्टाइल से सेट किए गए बैकग्राउंड कलर को ओवरराइड करता है.
val style1 = Style { background(Color.Red) contentPadding(32.dp) } val style2 = Style { contentPaddingHorizontal(8.dp) background(Color.LightGray) } BaseButton( style = style1 then style2, onClick = { }, ) { BaseText("Click me!") }
इस मामले में, लागू की गई स्टाइलिंग में हल्के ग्रे रंग का बैकग्राउंड और 32.dp पैडिंग है. हालांकि, बाईं और दाईं ओर की पैडिंग की वैल्यू 8.dp है.
contentPadding वाला बटन, जिसे अलग-अलग स्टाइल से ओवरराइड किया गया है.स्टाइल इनहेरिटेंस
कुछ स्टाइल प्रॉपर्टी, जैसे कि contentColor और टेक्स्ट स्टाइल से जुड़ी प्रॉपर्टी, चाइल्ड कंपोज़ेबल में फैलती हैं. चाइल्ड कंपोज़ेबल पर सेट की गई स्टाइल, उस खास चाइल्ड के लिए इनहेरिट की गई पैरंट स्टाइलिंग को ओवरराइड करती है.
Style, styleable, और डायरेक्ट पैरामीटर के साथ स्टाइल का प्रसार.| प्राथमिकता | तरीका | प्रभाव |
|---|---|---|
| 1 (सबसे ज़्यादा) | कंपोज़ेबल पर डायरेक्ट आर्ग्युमेंट | सब कुछ ओवरराइड करता है. उदाहरण के लिए, Text(color = Color.Red) |
| 2 | स्टाइल पैरामीटर | लोकल स्टाइल, Text(style = Style { contentColor(Color.Red)} को ओवरराइड करती है |
| 3 | मॉडिफ़ायर चेन | कॉम्पोनेंट पर Modifier.styleable{ contentColor(Color.Red). |
| 4 (सबसे कम) | पैरंट स्टाइल | इनहेरिट की जा सकने वाली प्रॉपर्टी (टाइपोग्राफ़ी/कलर) के लिए, जो पैरंट से पास की जाती हैं. |
पैरंट स्टाइलिंग
पैरंट कंपोज़ेबल से टेक्स्ट प्रॉपर्टी (जैसे, contentColor) सेट की जा सकती हैं. ये सभी चाइल्ड Text कंपोज़ेबल में फैलती हैं.
val styleState = remember { MutableStyleState(null) } Column( modifier = Modifier.styleable(styleState) { background(Color.LightGray) val blue = Color(0xFF4285F4) val purple = Color(0xFFA250EA) val colors = listOf(blue, purple) contentBrush(Brush.linearGradient(colors)) }, ) { BaseText("Children inherit", style = { width(60.dp) }) BaseText("certain properties") BaseText("from their parents") }
प्रॉपर्टी का चाइल्ड ओवरराइड
किसी खास Text कंपोज़ेबल पर भी स्टाइलिंग सेट की जा सकती है. अगर पैरंट कंपोज़ेबल पर स्टाइलिंग सेट की गई है, तो चाइल्ड कंपोज़ेबल पर सेट की गई स्टाइलिंग, पैरंट कंपोज़ेबल की स्टाइलिंग को ओवरराइड करती है.
val styleState = remember { MutableStyleState(null) } Column( modifier = Modifier.styleable(styleState) { background(Color.LightGray) val blue = Color(0xFF4285F4) val purple = Color(0xFFA250EA) val colors = listOf(blue, purple) contentBrush(Brush.linearGradient(colors)) }, ) { BaseText("Children can ", style = { contentBrush(Brush.linearGradient(listOf(Color.Red, Color.Blue))) }) BaseText("override properties") BaseText("set by their parents") }
कस्टम स्टाइल प्रॉपर्टी लागू करना
StyleScope पर एक्सटेंशन फ़ंक्शन का इस्तेमाल करके, कस्टम प्रॉपर्टी बनाई जा सकती हैं. ये प्रॉपर्टी, मौजूदा स्टाइल की परिभाषाओं से मैप होती हैं. इसके लिए, यहां दिया गया उदाहरण देखें:
fun StyleScope.outlinedBackground(color: Color) { border(1.dp, color) background(color) }
स्टाइल की परिभाषा में, इस नई प्रॉपर्टी को लागू करें:
val customExtensionStyle = Style { outlinedBackground(Color.Blue) }
स्टाइल की नई प्रॉपर्टी बनाने की सुविधा उपलब्ध नहीं है. अगर आपके इस्तेमाल के मामले में इस सुविधा की ज़रूरत है, तो सुविधा का अनुरोध सबमिट करें.
CompositionLocal की वैल्यू पढ़ना
डिज़ाइन सिस्टम टोकन को CompositionLocal में सेव करना एक आम पैटर्न है. इससे, वैरिएबल को पैरामीटर के तौर पर पास किए बिना ऐक्सेस किया जा सकता है. स्टाइल, CompositionLocal को ऐक्सेस करके, स्टाइल में सिस्टम-वाइड वैल्यू वापस पा सकती हैं:
val buttonStyle = Style { contentPadding(12.dp) shape(RoundedCornerShape(50)) background(Brush.verticalGradient(LocalCustomColors.currentValue.background)) }