রচনায় একটি থিমের অ্যানাটমি

জেটপ্যাক কম্পোজের থিমগুলি অনেকগুলি নিম্ন-স্তরের কনস্ট্রাক্ট এবং সম্পর্কিত APIগুলি নিয়ে গঠিত৷ এগুলো MaterialTheme এর সোর্স কোডে দেখা যায় এবং কাস্টম ডিজাইন সিস্টেমেও প্রয়োগ করা যেতে পারে।

থিম সিস্টেম ক্লাস

একটি থিম সাধারণত অনেকগুলি সাবসিস্টেম দ্বারা গঠিত হয় যা সাধারণ চাক্ষুষ এবং আচরণগত ধারণাগুলিকে গোষ্ঠীভুক্ত করে। এই সিস্টেমগুলি ক্লাসের সাথে মডেল করা যেতে পারে যার থিমিং মান রয়েছে।

উদাহরণ স্বরূপ, MaterialTheme মধ্যে ColorScheme (রঙ সিস্টেম), 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 সম্পর্কে আরও জানতে, CompositionLocal গাইডের সাথে স্থানীয়ভাবে স্কোপড ডেটা দেখুন।

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

থিম ফাংশন

থিম ফাংশন হল এন্ট্রি পয়েন্ট এবং প্রাথমিক API। এটি থিম সিস্টেম CompositionLocal s-এর দৃষ্টান্ত তৈরি করে — বাস্তব মান ব্যবহার করে যে কোনও যুক্তি প্রয়োজন — যা 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     /* ... */ }
{% শব্দার্থে %} {% endverbatim %} {% শব্দার্থে %} {% endverbatim %}