टेक्स्ट की शैली

Text कॉम्पोज़ेबल के कॉन्टेंट को स्टाइल करने के लिए, कई वैकल्पिक पैरामीटर मौजूद होते हैं. नीचे, हमने उन पैरामीटर की सूची दी है जो टेक्स्ट के साथ इस्तेमाल के सबसे सामान्य उदाहरणों को कवर करते हैं. Text के सभी पैरामीटर के लिए, टेक्स्ट सोर्स कोड लिखना देखें.

इनमें से किसी एक पैरामीटर को सेट करने पर, पूरी टेक्स्ट वैल्यू पर स्टाइल लागू हो जाती है. अगर आपको एक ही लाइन या पैराग्राफ़ में कई स्टाइल लागू करने हैं, तो एक से ज़्यादा इनलाइन स्टाइल सेक्शन देखें.

टेक्स्ट की आम स्टाइल

नीचे दिए गए सेक्शन में, टेक्स्ट का स्टाइल तय करने के सामान्य तरीकों के बारे में बताया गया है.

टेक्स्ट का रंग बदलना

@Composable
fun BlueText() {
    Text("Hello World", color = Color.Blue)
}

शब्द

टेक्स्ट साइज़ बदलना

@Composable
fun BigText() {
    Text("Hello World", fontSize = 30.sp)
}

शब्द

टेक्स्ट को इटैलिक करना

टेक्स्ट को इटैलिक करने के लिए, fontStyle पैरामीटर का इस्तेमाल करें (या कोई दूसरा FontStyle सेट करें).

@Composable
fun ItalicText() {
    Text("Hello World", fontStyle = FontStyle.Italic)
}

शब्द

टेक्स्ट को बोल्ड करना

टेक्स्ट को बोल्ड करने के लिए, fontWeight पैरामीटर का इस्तेमाल करें या कोई दूसरा FontWeight सेट करें.

@Composable
fun BoldText() {
    Text("Hello World", fontWeight = FontWeight.Bold)
}

शब्द

शैडो जोड़ना

style पैरामीटर की मदद से, TextStyle टाइप का ऑब्जेक्ट सेट किया जा सकता है और कई पैरामीटर कॉन्फ़िगर किए जा सकते हैं. जैसे, शैडो. Shadow को शैडो, ऑफ़सेट या Text के हिसाब से रंग मिलता है. साथ ही, धुंधला करने के लिए त्रिज्या का भी इस्तेमाल किया जाता है. इससे यह तय होता है कि ऑब्जेक्ट कितना धुंधला दिखेगा.

@Composable
fun TextShadow() {
    val offset = Offset(5.0f, 10.0f)
    Text(
        text = "Hello world!",
        style = TextStyle(
            fontSize = 24.sp,
            shadow = Shadow(
                color = Color.Blue, offset = offset, blurRadius = 3f
            )
        )
    )
}

शब्द

टेक्स्ट में एक से ज़्यादा स्टाइल जोड़ना

एक ही Text कॉम्पोज़ेबल में अलग-अलग स्टाइल सेट करने के लिए, AnnotatedString का इस्तेमाल करें. यह एक स्ट्रिंग है, जिसे अपनी पसंद के मुताबिक एनोटेशन की स्टाइल के साथ एनोटेट किया जा सकता है.

AnnotatedString एक डेटा क्लास है, जिसमें ये शामिल हैं:

  • Text वैल्यू
  • SpanStyleRange का List, जो टेक्स्ट वैल्यू में पोज़िशन रेंज के साथ इनलाइन स्टाइलिंग के बराबर है
  • ParagraphStyleRange का List, जिसमें टेक्स्ट अलाइनमेंट, टेक्स्ट की दिशा, लाइन की ऊंचाई, और टेक्स्ट इंडेंट स्टाइल की जानकारी दी गई है

TextStyle का इस्तेमाल, Text कॉम्पोज़ेबल में किया जाता है. वहीं, SpanStyle और ParagraphStyle का इस्तेमाल AnnotatedString में किया जाता है. पैराग्राफ़ में एक से ज़्यादा स्टाइल इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, पैराग्राफ़ में एक से ज़्यादा स्टाइल जोड़ना लेख पढ़ें.

AnnotatedString में टाइप-सेफ़ बिल्डर है, ताकि ये आसानी से बनाए जा सकें: buildAnnotatedString.

@Composable
fun MultipleStylesInText() {
    Text(
        buildAnnotatedString {
            withStyle(style = SpanStyle(color = Color.Blue)) {
                append("H")
            }
            append("ello ")

            withStyle(style = SpanStyle(fontWeight = FontWeight.Bold, color = Color.Red)) {
                append("W")
            }
            append("orld")
        }
    )
}

शब्द

अपने Jetpack Compose ऐप्लिकेशन में, क्लिक किए जा सकने वाले लिंक के साथ एचटीएमएल फ़ॉर्मैट वाला टेक्स्ट दिखाने के लिए, AnnotatedString.fromHtml() का इस्तेमाल करें. यह फ़ंक्शन, एचटीएमएल टैग वाली स्ट्रिंग को AnnotatedString में बदल देता है. इससे स्टाइल और लिंक मैनेज करने की सुविधा मिलती है.

उदाहरण: स्टाइल वाले लिंक वाला एचटीएमएल

यह स्निपेट, लिंक के साथ एचटीएमएल फ़ॉर्मैट वाला टेक्स्ट रेंडर करता है. साथ ही, लिंक पर खास स्टाइल लागू करता है:

कोड के बारे में अहम जानकारी
  • AnnotatedString.fromHtml(), htmlText स्ट्रिंग को AnnotatedString में बदल देता है. linkStyles पैरामीटर, लिंक के दिखने के तरीके को पसंद के मुताबिक बनाता है.

  • TextLinkStyles, एचटीएमएल में लिंक की स्टाइल तय करता है. SpanStyle, लिंक के लिए टेक्स्ट डेकोरेशन, फ़ॉन्ट स्टाइल, और रंग सेट करता है.

  • Text कंपोज़ेबल, नतीजा AnnotatedString दिखाता है.

नतीजा

इस स्निपेट की मदद से, "Jetpack Compose" को क्लिक किए जा सकने वाले लिंक के तौर पर दिखाया जा सकता है. साथ ही, इसे नीले रंग में, अंडरलाइन करके, और इटैलिक में लिखा जा सकता है:

H1 हेडिंग 'Jetpack Compose' के बाद 'Jetpack Compose की मदद से बेहतर ऐप्लिकेशन बनाएं'. इसमें Jetpack Compose, क्लिक किए जा सकने वाले लिंक के तौर पर नीले रंग, अंडरलाइन, और इटैलिक में है.
दूसरी इमेज. एक हेडिंग और पैराग्राफ़, जिसमें पैराग्राफ़ में 'Jetpack Compose' एक क्लिक किया जा सकने वाला और स्टाइल वाला लिंक है.

Brush की मदद से, स्टाइल की बेहतर सुविधाएं चालू करना

टेक्स्ट की स्टाइल को ज़्यादा बेहतर बनाने के लिए, TextStyle और SpanStyle के साथ Brush एपीआई का इस्तेमाल किया जा सकता है. आम तौर पर, जहां TextStyle या SpanStyle का इस्तेमाल किया जाता है वहां अब Brush का भी इस्तेमाल किया जा सकता है.

टेक्स्ट की स्टाइल तय करने के लिए ब्रश का इस्तेमाल करना

TextStyle में पहले से मौजूद ब्रश का इस्तेमाल करके, अपना टेक्स्ट कॉन्फ़िगर करें. उदाहरण के लिए, अपने टेक्स्ट के लिए linearGradient ब्रश को इस तरह कॉन्फ़िगर किया जा सकता है:

val gradientColors = listOf(Cyan, LightBlue, Purple /*...*/)

Text(
    text = text,
    style = TextStyle(
        brush = Brush.linearGradient(
            colors = gradientColors
        )
    )
)

Brush API के `linearGradient` फ़ंक्शन का इस्तेमाल करके, रंगों की तय सूची के साथ.
तीसरी इमेज. रंगों की तय सूची के साथ, Brush API के linearGradient फ़ंक्शन का इस्तेमाल करना.

आपको इस कलर स्कीम या रंग भरने के स्टाइल का इस्तेमाल करना ज़रूरी नहीं है. हमने हाइलाइट करने के लिए एक आसान उदाहरण दिया है. हालांकि, अपने टेक्स्ट को बेहतर बनाने के लिए, पहले से मौजूद किसी भी ब्रश या सिर्फ़ SolidColor का इस्तेमाल करें.

इंटिग्रेशन

Brush का इस्तेमाल TextStyle और SpanStyle, दोनों के साथ किया जा सकता है. इसलिए, TextField और buildAnnotatedString के साथ इंटिग्रेशन करना आसान है.

TextField में ब्रश एपीआई का इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, Brush API की मदद से स्टाइल इनपुट देखें.

SpanStyle का इस्तेमाल करके अतिरिक्त स्टाइल

टेक्स्ट के किसी हिस्से पर ब्रश लागू करना

अगर आपको अपने टेक्स्ट के कुछ हिस्सों पर ही ब्रश का इस्तेमाल करना है, तो अपने पसंदीदा ब्रश और ग्रेडिएंट के साथ-साथ, buildAnnotatedString और SpanStyle एपीआई का इस्तेमाल करें.

Text(
    text = buildAnnotatedString {
        append("Do not allow people to dim your shine\n")
        withStyle(
            SpanStyle(
                brush = Brush.linearGradient(
                    colors = rainbowColors
                )
            )
        ) {
            append("because they are blinded.")
        }
        append("\nTell them to put some sunglasses on.")
    }
)

टेक्स्ट के लिए स्टाइल के तौर पर, linearGradient के साथ डिफ़ॉल्ट ब्रश का इस्तेमाल करना.
चौथी इमेज. Text के लिए स्टाइल के तौर पर, linearGradient के साथ डिफ़ॉल्ट ब्रश का इस्तेमाल करना.
टेक्स्ट के किसी हिस्से की अपारदर्शिता

टेक्स्ट के किसी खास हिस्से की ओपैसिटी में बदलाव करने के लिए, SpanStyle के वैकल्पिक alpha पैरामीटर का इस्तेमाल करें. टेक्स्ट के दोनों हिस्सों के लिए एक ही ब्रश का इस्तेमाल करें और उससे जुड़े स्पैन में अल्फा पैरामीटर बदलें. कोड सैंपल में, टेक्स्ट का पहला स्पैन आधी ऑपैसिटी (alpha =.5f) पर दिखता है, जबकि दूसरा स्पैन पूरी ऑपैसिटी (alpha = 1f) पर दिखता है.

val brush = Brush.linearGradient(colors = rainbowColors)

buildAnnotatedString {
    withStyle(
        SpanStyle(
            brush = brush, alpha = .5f
        )
    ) {
        append("Text in ")
    }
    withStyle(
        SpanStyle(
            brush = brush, alpha = 1f
        )
    ) {
        append("Compose ❤️")
    }
}

टेक्स्ट के स्पैन में ओपैसिटी जोड़ने के लिए, buildAnnotatedString और SpanStyle के alpha पैरामीटर के साथ-साथ linearGradient का इस्तेमाल करना.
पांचवीं इमेज. टेक्स्ट के किसी स्पैन में ओपैसिटी जोड़ने के लिए, linearGradient के साथ-साथ buildAnnotatedString और SpanStyle के अल्फा पैरामीटर का इस्तेमाल करना.

अन्य संसाधन

कस्टमाइज़ेशन के अन्य उदाहरणों के लिए, कॉम्पोज़ टेक्स्ट के रंग को बेहतर बनाना ब्लॉग पोस्ट देखें. अगर आपको Brush के हमारे ऐनिमेशन एपीआई के साथ इंटिग्रेट होने के तरीके के बारे में ज़्यादा जानना है, तो Compose में ब्रश के टेक्स्ट को ऐनिमेट करके रंग भरना लेख पढ़ें.

टेक्स्ट पर मार्की इफ़ेक्ट लागू करना

ऐनिमेशन वाला स्क्रोलिंग इफ़ेक्ट पाने के लिए, किसी भी कॉम्पोज़ेबल पर basicMarquee मॉडिफ़ायर लागू किया जा सकता है. मार्की इफ़ेक्ट तब दिखता है, जब कॉन्टेंट उपलब्ध सीमाओं में फ़िट न हो. डिफ़ॉल्ट रूप से, basicMarquee में कुछ कॉन्फ़िगरेशन (जैसे, वेग और शुरुआती देरी) सेट होते हैं. हालांकि, इफ़ेक्ट को पसंद के मुताबिक बनाने के लिए, इन पैरामीटर में बदलाव किया जा सकता है.

यहां दिया गया स्निपेट, Text कॉम्पोज़ेबल पर मार्की इफ़ेक्ट लागू करता है:

@Composable
fun BasicMarqueeSample() {
    // Marquee only animates when the content doesn't fit in the max width.
    Column(Modifier.width(400.dp)) {
        Text(
            "Learn about why it's great to use Jetpack Compose",
            modifier = Modifier.basicMarquee(),
            fontSize = 50.sp
        )
    }
}

छठी इमेज. टेक्स्ट पर लागू किया गया basicMarquee मॉडिफ़ायर.