শৈলী পাঠ্য

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 টাইপের একটি অবজেক্ট সেট করতে এবং একাধিক প্যারামিটার কনফিগার করতে দেয়, উদাহরণস্বরূপ ছায়া। Text এবং ব্লার ব্যাসার্ধের সাপেক্ষে ছায়া, অফসেট বা যেখানে এটি অবস্থিত তার জন্য Shadow একটি রঙ পায় যা দেখতে কতটা অস্পষ্ট।

@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")
        }
    )
}

শব্দ

আপনার জেটপ্যাক রচনা অ্যাপ্লিকেশনে ক্লিকযোগ্য লিঙ্কগুলির সাথে HTML-ফরম্যাট করা পাঠ্য প্রদর্শন করতে AnnotatedString.fromHtml() ব্যবহার করুন। এই ফাংশনটি HTML ট্যাগ সহ একটি স্ট্রিংকে AnnotatedString এ রূপান্তর করে, যা স্টাইলিং এবং লিঙ্ক পরিচালনার জন্য অনুমতি দেয়।

উদাহরণ: শৈলীযুক্ত লিঙ্ক সহ HTML

এই স্নিপেটটি একটি লিঙ্কের সাথে HTML-ফরম্যাট করা পাঠ্য রেন্ডার করে, লিঙ্কটিতে নির্দিষ্ট স্টাইলিং প্রয়োগ করে:

কোড সম্পর্কে মূল পয়েন্ট
  • AnnotatedString.fromHtml() htmlText স্ট্রিংকে AnnotatedString এ রূপান্তর করে। linkStyles প্যারামিটার লিঙ্কের চেহারা কাস্টমাইজ করে।

  • TextLinkStyles HTML-এর মধ্যে লিঙ্কগুলির জন্য শৈলী সংজ্ঞায়িত করে। SpanStyle লিঙ্কগুলির জন্য পাঠ্য সজ্জা, ফন্ট শৈলী এবং রঙ সেট করে।

  • Text কম্পোজেবল ফলস্বরূপ AnnotatedString প্রদর্শন করে।

ফলাফল

এই স্নিপেটটি "জেটপ্যাক রচনা"কে একটি ক্লিকযোগ্য লিঙ্ক হিসাবে সক্ষম করে, নীল রঙ দিয়ে স্টাইল করা, আন্ডারলাইন করা এবং তির্যক করা:

একটি H1 শিরোনাম 'জেটপ্যাক কম্পোজ' এর পরে 'জেটপ্যাক দিয়ে আরও ভাল অ্যাপ তৈরি করুন'     কম্পোজ', যেখানে জেটপ্যাক কম্পোজ হল নীল রঙের স্টাইল করা একটি ক্লিকযোগ্য লিঙ্ক,     আন্ডারলাইন, এবং তির্যক।
চিত্র 2. একটি শিরোনাম এবং অনুচ্ছেদ, যেখানে অনুচ্ছেদে 'জেটপ্যাক রচনা' একটি ক্লিকযোগ্য, স্টাইলযুক্ত লিঙ্ক।

Brush দিয়ে উন্নত স্টাইলিং সক্ষম করুন

আরও উন্নত টেক্সট স্টাইলিং সক্ষম করতে, আপনি TextStyle এবং SpanStyle সাথে Brush API ব্যবহার করতে পারেন। যেকোন জায়গায় যেখানে আপনি সাধারণত TextStyle বা SpanStyle ব্যবহার করবেন, আপনি এখন Brush ব্যবহার করতে পারেন।

টেক্সট স্টাইলিং জন্য একটি ব্রাশ ব্যবহার করুন

TextStyle মধ্যে অন্তর্নির্মিত ব্রাশ ব্যবহার করে আপনার পাঠ্য কনফিগার করুন। উদাহরণস্বরূপ, আপনি নিম্নরূপ আপনার পাঠ্যের সাথে একটি linearGradient ব্রাশ কনফিগার করতে পারেন:

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

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

রঙের একটি সংজ্ঞায়িত তালিকা সহ Brush API এর `লিনিয়ার গ্রেডিয়েন্ট` ফাংশন ব্যবহার করা।
চিত্র 3. রঙের একটি সংজ্ঞায়িত তালিকা সহ ব্রাশ API এর linearGradient ফাংশন ব্যবহার করা।

আপনি এই নির্দিষ্ট রঙের স্কিম বা রঙের শৈলীতে সীমাবদ্ধ নন। যদিও আমরা হাইলাইট করার জন্য একটি সহজ উদাহরণ দিয়েছি, আপনার টেক্সট উন্নত করতে বিল্ট-ইন ব্রাশ বা এমনকি শুধুমাত্র একটি SolidColor ব্যবহার করুন।

ইন্টিগ্রেশন

যেহেতু আপনি TextStyle এবং SpanStyle উভয়ের পাশাপাশি Brush ব্যবহার করতে পারেন, তাই TextField এবং buildAnnotatedString সাথে একীকরণ বিরামহীন।

TextField মধ্যে ব্রাশ API ব্যবহার সম্পর্কে আরও তথ্যের জন্য, ব্রাশ API-এর সাথে স্টাইল ইনপুট দেখুন।

SpanStyle ব্যবহার করে অতিরিক্ত স্টাইলিং

পাঠ্যের একটি স্প্যানে একটি ব্রাশ প্রয়োগ করুন

আপনি যদি শুধুমাত্র আপনার পাঠ্যের অংশগুলিতে একটি ব্রাশ প্রয়োগ করতে চান তবে আপনার পছন্দের ব্রাশ এবং গ্রেডিয়েন্ট সহ buildAnnotatedString এবং SpanStyle API ব্যবহার করুন।

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.")
    }
)

টেক্সটের জন্য স্টাইল হিসাবে লিনিয়ার গ্রেডিয়েন্ট সহ একটি ডিফল্ট ব্রাশ ব্যবহার করা।
চিত্র 4. 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 ❤️")
    }
}

বিল্ডঅ্যানোটেটেড স্ট্রিং এবং স্প্যানস্টাইলের আলফা প্যারামিটার ব্যবহার করে, রৈখিক গ্রেডিয়েন্ট সহ পাঠ্যের একটি স্প্যানে অস্বচ্ছতা যোগ করতে।
চিত্র 5. buildAnnotatedString এবং SpanStyle আলফা প্যারামিটার ব্যবহার করে, linearGradient সহ পাঠ্যের একটি স্প্যানে অস্বচ্ছতা যোগ করতে।

অতিরিক্ত সম্পদ

অতিরিক্ত কাস্টমাইজেশন উদাহরণের জন্য, কম্পোজ টেক্সট কালারিং ব্লগ পোস্টে ব্রাশিং আপ দেখুন। আপনি যদি আমাদের অ্যানিমেশন API-এর সাথে Brush কীভাবে একীভূত হয় সে সম্পর্কে আরও জানতে আগ্রহী হন, কম্পোজে অ্যানিমেটিং ব্রাশ টেক্সট কালারিং দেখুন।

পাঠ্যে মার্কি প্রভাব প্রয়োগ করুন

আপনি একটি অ্যানিমেটেড স্ক্রোলিং প্রভাব তৈরি করতে যেকোন কম্পোজেবলে 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
        )
    }
}

চিত্র 6. basicMarquee মডিফায়ার পাঠ্যে প্রয়োগ করা হয়েছে।

{% শব্দার্থে %} {% endverbatim %} {% শব্দার্থে %} {% endverbatim %}