अपने ऐप्लिकेशन में स्टाइल लागू करने के तीन तरीके हैं:
- मौजूदा कॉम्पोनेंट पर सीधे तौर पर स्टाइल लागू करना. इसके लिए, कॉम्पोनेंट में
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)) }