Compose में किसी थीम की बनावट

Jetpack Compose की थीम कई निचले लेवल के कंस्ट्रक्शन से मिलकर बनी हैं और संबंधित एपीआई. इन्हें यहां देखा जा सकता है: सोर्स कोड MaterialTheme है और इसे कस्टम डिज़ाइन सिस्टम में भी लागू किया जा सकता है.

थीम सिस्टम की क्लास

आम तौर पर, किसी थीम में कई सिस्टम होते हैं. ये सिस्टम एक जैसे विज़ुअल और व्यवहार से जुड़े सिद्धांत. इन सिस्टम को क्लास के साथ मॉडल किया जा सकता है, जिनमें थीम के हिसाब से वैल्यू तय करें.

उदाहरण के लिए, MaterialTheme में शामिल है Colors (कलर सिस्टम), Typography (टाइपोग्राफ़ी सिस्टम), और Shapes (शेप सिस्टम).

@Immutable
data class ColorSystem(
    val color: Color,
    val gradient: List<Color>
    /* ... */
)

@Immutable
data class TypographySystem(
    val fontFamily: FontFamily,
    val textStyle: TextStyle
)
/* ... */

@Immutable
data class CustomSystem(
    val value1: Int,
    val value2: String
    /* ... */
)

/* ... */

थीम सिस्टम कंपोज़िशन लोकल

थीम सिस्टम क्लास, कंपोज़िशन ट्री में इस तरह से दी जाती हैं CompositionLocal इंस्टेंस. इससे कंपोज़ेबल में थीम की वैल्यू को स्टैटिक तौर पर रेफ़र किया जा सकता है फ़ंक्शन.

CompositionLocal के बारे में ज़्यादा जानने के लिए, यहां जाएं: कंपोज़िशन Local गाइड के साथ स्थानीय तौर पर स्कोप वाला डेटा.

val LocalColorSystem = staticCompositionLocalOf {
    ColorSystem(
        color = Color.Unspecified,
        gradient = emptyList()
    )
}

val LocalTypographySystem = staticCompositionLocalOf {
    TypographySystem(
        fontFamily = FontFamily.Default,
        textStyle = TextStyle.Default
    )
}

val LocalCustomSystem = staticCompositionLocalOf {
    CustomSystem(
        value1 = 0,
        value2 = ""
    )
}

/* ... */

थीम फ़ंक्शन

थीम फ़ंक्शन, एंट्री पॉइंट और प्राइमरी एपीआई होता है. यह इंस्टेंस बनाता है थीम सिस्टम CompositionLocals — किसी भी लॉजिक का इस्तेमाल करके ज़रूरी — जो कंपोज़िशन ट्री को दिए जाते हैं. CompositionLocalProvider. content पैरामीटर की मदद से, नेस्ट किए गए कंपोज़ेबल, थीम वाली वैल्यू ऐक्सेस कर सकते हैं के हिसाब से क्रम में लगाया जाता है.

@Composable
fun Theme(
    /* ... */
    content: @Composable () -> Unit
) {
    val colorSystem = ColorSystem(
        color = Color(0xFF3DDC84),
        gradient = listOf(Color.White, Color(0xFFD7EFFF))
    )
    val typographySystem = TypographySystem(
        fontFamily = FontFamily.Monospace,
        textStyle = TextStyle(fontSize = 18.sp)
    )
    val customSystem = CustomSystem(
        value1 = 1000,
        value2 = "Custom system"
    )
    /* ... */
    CompositionLocalProvider(
        LocalColorSystem provides colorSystem,
        LocalTypographySystem provides typographySystem,
        LocalCustomSystem provides customSystem,
        /* ... */
        content = content
    )
}

थीम ऑब्जेक्ट

थीम सिस्टम को, आसानी से इस्तेमाल की जाने वाली प्रॉपर्टी वाले ऑब्जेक्ट के ज़रिए ऐक्सेस किया जाता है. इसके लिए एक जैसा होने पर, ऑब्जेक्ट का नाम थीम फ़ंक्शन जैसा ही होता है. कॉन्टेंट बनाने प्रॉपर्टी को सिर्फ़ मौजूदा कंपोज़िशन स्थानीय मिलती है.

// Use with eg. Theme.colorSystem.color
object Theme {
    val colorSystem: ColorSystem
        @Composable
        get() = LocalColorSystem.current
    val typographySystem: TypographySystem
        @Composable
        get() = LocalTypographySystem.current
    val customSystem: CustomSystem
        @Composable
        get() = LocalCustomSystem.current
    /* ... */
}