সংশোধক আপনাকে একটি কম্পোজেবল সাজাতে বা বৃদ্ধি করতে দেয়। সংশোধক আপনাকে এই ধরণের জিনিসগুলি করতে দেয়:
- কম্পোজেবলের আকার, বিন্যাস, আচরণ এবং চেহারা পরিবর্তন করুন
- তথ্য যোগ করুন, যেমন অ্যাক্সেসিবিলিটি লেবেল
- ব্যবহারকারীর ইনপুট প্রক্রিয়া করুন
- উচ্চ-স্তরের মিথস্ক্রিয়া যোগ করুন, যেমন একটি উপাদান ক্লিকযোগ্য, স্ক্রোলযোগ্য, টেনে আনা বা জুমযোগ্য করা
সংশোধকগুলি স্ট্যান্ডার্ড কোটলিন অবজেক্ট। Modifier
শ্রেণীর ফাংশনগুলির একটিতে কল করে একটি সংশোধক তৈরি করুন:
@Composable private fun Greeting(name: String) { Column(modifier = Modifier.padding(24.dp)) { Text(text = "Hello,") Text(text = name) } }
আপনি তাদের রচনা করতে এই ফাংশনগুলিকে একসাথে চেইন করতে পারেন:
@Composable private fun Greeting(name: String) { Column( modifier = Modifier .padding(24.dp) .fillMaxWidth() ) { Text(text = "Hello,") Text(text = name) } }
উপরের কোডে, একসাথে ব্যবহৃত বিভিন্ন মডিফায়ার ফাংশন লক্ষ্য করুন।
-
padding
একটি উপাদানের চারপাশে স্থান রাখে। -
fillMaxWidth
তার অভিভাবক থেকে প্রদত্ত সর্বাধিক প্রস্থ কম্পোজযোগ্য পূরণ করে।
আপনার সমস্ত কম্পোজেবল একটি modifier
পরামিতি গ্রহণ করে এবং সেই সংশোধকটিকে তার প্রথম সন্তানের কাছে প্রেরণ করা একটি সর্বোত্তম অনুশীলন যা UI নির্গত করে৷ এটি করা আপনার কোডকে আরও পুনঃব্যবহারযোগ্য করে তোলে এবং এর আচরণকে আরও অনুমানযোগ্য এবং স্বজ্ঞাত করে তোলে। আরও তথ্যের জন্য, রচনা API নির্দেশিকা দেখুন, উপাদানগুলি একটি পরিবর্তনকারী পরামিতি গ্রহণ করে এবং সম্মান করে ।
সংশোধক বিষয়ের ক্রম
মডিফায়ার ফাংশনের ক্রম উল্লেখযোগ্য । যেহেতু প্রতিটি ফাংশন পূর্ববর্তী ফাংশন দ্বারা প্রত্যাবর্তিত Modifier
পরিবর্তন করে, তাই ক্রম চূড়ান্ত ফলাফলকে প্রভাবিত করে। এর একটি উদাহরণ দেখা যাক:
@Composable fun ArtistCard(/*...*/) { val padding = 16.dp Column( Modifier .clickable(onClick = onClick) .padding(padding) .fillMaxWidth() ) { // rest of the implementation } }
উপরের কোডে আশেপাশের প্যাডিং সহ পুরো এলাকাটি ক্লিকযোগ্য, কারণ clickable
মডিফায়ারের পরে padding
মডিফায়ার প্রয়োগ করা হয়েছে। যদি মডিফায়ার অর্ডার বিপরীত হয়, padding
দ্বারা যোগ করা স্থান ব্যবহারকারীর ইনপুটে প্রতিক্রিয়া দেখায় না:
@Composable fun ArtistCard(/*...*/) { val padding = 16.dp Column( Modifier .padding(padding) .clickable(onClick = onClick) .fillMaxWidth() ) { // rest of the implementation } }
অন্তর্নির্মিত সংশোধক
জেটপ্যাক কম্পোজ বিল্ট-ইন সংশোধকগুলির একটি তালিকা প্রদান করে যা আপনাকে একটি কম্পোজেবল সাজাতে বা বৃদ্ধি করতে সহায়তা করে। এখানে কিছু সাধারণ সংশোধক রয়েছে যা আপনি আপনার লেআউটগুলি সামঞ্জস্য করতে ব্যবহার করবেন৷
padding
এবং size
ডিফল্টরূপে, কম্পোজে প্রদত্ত লেআউটগুলি তাদের বাচ্চাদের মোড়ানো। যাইহোক, আপনি size
পরিবর্তনকারী ব্যবহার করে একটি আকার সেট করতে পারেন:
@Composable fun ArtistCard(/*...*/) { Row( modifier = Modifier.size(width = 400.dp, height = 100.dp) ) { Image(/*...*/) Column { /*...*/ } } }
মনে রাখবেন যে আপনি যে আকারটি নির্দিষ্ট করেছেন সেটি সম্মানিত নাও হতে পারে যদি এটি লেআউটের অভিভাবক থেকে আসা সীমাবদ্ধতাগুলিকে সন্তুষ্ট না করে। আগত সীমাবদ্ধতা নির্বিশেষে আপনার যদি সংমিশ্রণযোগ্য আকারটি স্থির করার প্রয়োজন হয়, requiredSize
পরিবর্তনকারী ব্যবহার করুন:
@Composable fun ArtistCard(/*...*/) { Row( modifier = Modifier.size(width = 400.dp, height = 100.dp) ) { Image( /*...*/ modifier = Modifier.requiredSize(150.dp) ) Column { /*...*/ } } }
এই উদাহরণে, এমনকি প্যারেন্ট height
100.dp
এ সেট করা থাকলেও, Image
উচ্চতা হবে 150.dp
, কারণ requiredSize
মডিফায়ার অগ্রাধিকার নেয়।
আপনি যদি চান যে একটি চাইল্ড লেআউট পিতামাতার দ্বারা অনুমোদিত সমস্ত উপলব্ধ উচ্চতা পূরণ করতে, fillMaxHeight
সংশোধক যোগ করুন (কম্পোজ এছাড়াও fillMaxSize
এবং fillMaxWidth
প্রদান করে):
@Composable fun ArtistCard(/*...*/) { Row( modifier = Modifier.size(width = 400.dp, height = 100.dp) ) { Image( /*...*/ modifier = Modifier.fillMaxHeight() ) Column { /*...*/ } } }
একটি উপাদানের চারপাশে প্যাডিং যোগ করতে, একটি padding
সংশোধক সেট করুন।
আপনি যদি একটি পাঠ্য বেসলাইনের উপরে প্যাডিং যুক্ত করতে চান যাতে আপনি লেআউটের শীর্ষ থেকে বেসলাইনে একটি নির্দিষ্ট দূরত্ব অর্জন করতে পারেন, তাহলে paddingFromBaseline
সংশোধক ব্যবহার করুন:
@Composable fun ArtistCard(artist: Artist) { Row(/*...*/) { Column { Text( text = artist.name, modifier = Modifier.paddingFromBaseline(top = 50.dp) ) Text(artist.lastSeenOnline) } } }
অফসেট
একটি লেআউটকে তার আসল অবস্থানের সাথে সম্পর্কিত করতে, offset
মডিফায়ার যোগ করুন এবং অফসেটটিকে x এবং y অক্ষে সেট করুন। অফসেটগুলি ইতিবাচক এবং অ-ইতিবাচক হতে পারে। padding
এবং offset
মধ্যে পার্থক্য হল যে একটি কম্পোজেবলে একটি offset
যোগ করলে এর পরিমাপ পরিবর্তন হয় না:
@Composable fun ArtistCard(artist: Artist) { Row(/*...*/) { Column { Text(artist.name) Text( text = artist.lastSeenOnline, modifier = Modifier.offset(x = 4.dp) ) } } }
offset
মডিফায়ার লেআউট দিক অনুযায়ী অনুভূমিকভাবে প্রয়োগ করা হয়। একটি বাম থেকে ডান প্রেক্ষাপটে, একটি ইতিবাচক offset
উপাদানটিকে ডানে স্থানান্তরিত করে, যখন একটি ডান থেকে বাম প্রসঙ্গে, এটি উপাদানটিকে বামে স্থানান্তরিত করে৷ লেআউটের দিক বিবেচনা না করে যদি আপনি একটি অফসেট সেট করতে চান, তাহলে absoluteOffset
সংশোধক দেখুন, যেখানে একটি ইতিবাচক অফসেট মান সর্বদা উপাদানটিকে ডানদিকে স্থানান্তরিত করে।
offset
মডিফায়ার দুটি ওভারলোড প্রদান করে - offset
যা অফসেটগুলিকে প্যারামিটার হিসাবে নেয় এবং offset
যা ল্যাম্বডায় নেয়৷ এইগুলির প্রতিটি কখন ব্যবহার করতে হবে এবং কীভাবে পারফরম্যান্সের জন্য অপ্টিমাইজ করতে হবে সে সম্পর্কে আরও গভীর তথ্যের জন্য, রচনা কর্মক্ষমতা পড়ুন - যতক্ষণ সম্ভব পঠন স্থগিত করুন ৷
রচনায় স্কোপ নিরাপত্তা
কম্পোজে, এমন কিছু সংশোধক রয়েছে যা শুধুমাত্র নির্দিষ্ট কম্পোজেবলের শিশুদের ক্ষেত্রে প্রয়োগ করা যেতে পারে। কম্পোজ কাস্টম স্কোপের মাধ্যমে এটি প্রয়োগ করে।
উদাহরণস্বরূপ, আপনি যদি Box
আকারকে প্রভাবিত না করে একটি শিশুকে প্যারেন্ট Box
মতো বড় করতে চান তবে matchParentSize
মডিফায়ার ব্যবহার করুন৷ matchParentSize
শুধুমাত্র BoxScope
এ উপলব্ধ। অতএব, এটি শুধুমাত্র একটি Box
পিতামাতার মধ্যে একটি শিশুর উপর ব্যবহার করা যেতে পারে।
স্কোপ নিরাপত্তা আপনাকে মডিফায়ার যোগ করা থেকে বাধা দেয় যা অন্য কম্পোজেবল এবং স্কোপে কাজ করবে না এবং ট্রায়াল এবং ত্রুটি থেকে সময় বাঁচায়।
স্কোপড মডিফায়ারগুলি পিতামাতাকে কিছু তথ্য সম্পর্কে অবহিত করে যা পিতামাতার সন্তান সম্পর্কে জানা উচিত। এগুলিকে সাধারণত প্যারেন্ট ডেটা মডিফায়ার হিসাবেও উল্লেখ করা হয়। তাদের অভ্যন্তরীণ সাধারণ উদ্দেশ্য সংশোধক থেকে ভিন্ন, কিন্তু একটি ব্যবহারের দৃষ্টিকোণ থেকে, এই পার্থক্যগুলি গুরুত্বপূর্ণ নয়।
প্যারেন্টসাইজ ইন Box
matchParentSize
উপরে উল্লিখিত হিসাবে, আপনি যদি Box
আকারকে প্রভাবিত না করে একটি শিশুর বিন্যাসটি প্যারেন্ট Box
মতো একই আকারের হতে চান তবে matchParentSize
মডিফায়ার ব্যবহার করুন৷
মনে রাখবেন matchParentSize
শুধুমাত্র একটি Box
স্কোপের মধ্যে উপলব্ধ, যার অর্থ এটি শুধুমাত্র Box
কম্পোজেবলের সরাসরি শিশুদের জন্য প্রযোজ্য।
নীচের উদাহরণে, চাইল্ড Spacer
মাপ তার প্যারেন্ট Box
থেকে নেয়, যা এই ক্ষেত্রে সবচেয়ে বড় বাচ্চাদের ArtistCard
থেকে তার আকার নেয়।
@Composable fun MatchParentSizeComposable() { Box { Spacer( Modifier .matchParentSize() .background(Color.LightGray) ) ArtistCard() } }
যদি matchParentSize
এর পরিবর্তে fillMaxSize
ব্যবহার করা হয়, তাহলে Spacer
অভিভাবকের কাছে অনুমোদিত সমস্ত উপলব্ধ স্থান নিয়ে যাবে, যার ফলে অভিভাবক সমস্ত উপলব্ধ স্থান প্রসারিত করতে এবং পূরণ করতে পারে।
Row
এবং Column
weight
যেমনটি আপনি প্যাডিং এবং আকারের পূর্ববর্তী বিভাগে দেখেছেন, ডিফল্টরূপে, একটি সংমিশ্রণযোগ্য আকার এটি মোড়ানো সামগ্রী দ্বারা সংজ্ঞায়িত করা হয়। আপনি weight
মডিফায়ার ব্যবহার করে এর প্যারেন্টের মধ্যে নমনীয় হওয়ার জন্য একটি সংমিশ্রণযোগ্য আকার সেট করতে পারেন যা শুধুমাত্র RowScope
এবং ColumnScope
এ উপলব্ধ।
একটি Row
নেওয়া যাক যেখানে দুটি Box
কম্পোজেবল রয়েছে। প্রথম বাক্সটি দ্বিতীয়টির weight
দ্বিগুণ দেওয়া হয়েছে, তাই এটি প্রস্থের দ্বিগুণ দেওয়া হয়েছে। যেহেতু Row
210.dp
প্রশস্ত, প্রথম Box
140.dp
চওড়া এবং দ্বিতীয়টি 70.dp
:
@Composable fun ArtistCard(/*...*/) { Row( modifier = Modifier.fillMaxWidth() ) { Image( /*...*/ modifier = Modifier.weight(2f) ) Column( modifier = Modifier.weight(1f) ) { /*...*/ } } }
সংশোধক নিষ্কাশন এবং পুনরায় ব্যবহার
একাধিক সংশোধককে একটি কম্পোজেবল সাজাতে বা বাড়ানোর জন্য একসাথে চেইন করা যেতে পারে। এই চেইনটি Modifier
ইন্টারফেসের মাধ্যমে তৈরি করা হয়েছে যা একক Modifier.Elements
একটি অর্ডারকৃত, অপরিবর্তনীয় তালিকা উপস্থাপন করে।
প্রতিটি Modifier.Element
একটি স্বতন্ত্র আচরণের প্রতিনিধিত্ব করে, যেমন লেআউট, অঙ্কন এবং গ্রাফিক্স আচরণ, সমস্ত অঙ্গভঙ্গি-সম্পর্কিত, ফোকাস এবং শব্দার্থবিদ্যা আচরণ, সেইসাথে ডিভাইস ইনপুট ইভেন্ট। তাদের ক্রমবিন্যাস বিষয়: সংশোধক উপাদানগুলি যা প্রথমে যোগ করা হয় তা প্রথমে প্রয়োগ করা হবে।
কখনও কখনও একই মডিফায়ার চেইন ইনস্ট্যান্সগুলিকে একাধিক কম্পোজেবলে পুনঃব্যবহার করা উপকারী হতে পারে, সেগুলিকে ভেরিয়েবলের মধ্যে বের করে উচ্চতর স্কোপে উত্তোলন করে৷ এটি কোড পঠনযোগ্যতা উন্নত করতে পারে বা কয়েকটি কারণে আপনার অ্যাপের কর্মক্ষমতা উন্নত করতে সাহায্য করতে পারে:
- সংশোধকগুলির পুনরায় বরাদ্দকরণের পুনরাবৃত্তি হবে না যখন কম্পোজেবলগুলির জন্য পুনর্গঠন ঘটে যা তাদের ব্যবহার করে
- সংশোধক চেইনগুলি সম্ভাব্যভাবে খুব দীর্ঘ এবং জটিল হতে পারে, তাই একটি চেইনের একই দৃষ্টান্ত পুনঃব্যবহার করা কাজের চাপ কমিয়ে দিতে পারে কম্পোজ রানটাইম তাদের তুলনা করার সময় যা করতে হবে
- এই নিষ্কাশন কোডবেস জুড়ে কোড পরিচ্ছন্নতা, ধারাবাহিকতা এবং রক্ষণাবেক্ষণের প্রচার করে
সংশোধক পুনঃব্যবহারের জন্য সর্বোত্তম অনুশীলন
আপনার নিজস্ব Modifier
চেইন তৈরি করুন এবং একাধিক সংমিশ্রণযোগ্য উপাদানগুলিতে পুনঃব্যবহার করতে সেগুলি বের করুন। শুধুমাত্র একটি সংশোধক সংরক্ষণ করা সম্পূর্ণরূপে সূক্ষ্ম, কারণ সেগুলি ডেটার মতো বস্তু:
val reusableModifier = Modifier .fillMaxWidth() .background(Color.Red) .padding(12.dp)
ঘন ঘন পরিবর্তিত অবস্থা পর্যবেক্ষণ করার সময় সংশোধকগুলি নিষ্কাশন এবং পুনরায় ব্যবহার করা
অ্যানিমেশন স্টেট বা scrollState
মতো কম্পোজেবলের ভিতরে ঘন ঘন পরিবর্তনশীল অবস্থা পর্যবেক্ষণ করার সময়, উল্লেখযোগ্য পরিমাণে পুনর্গঠন করা যেতে পারে। এই ক্ষেত্রে, আপনার সংশোধকগুলি প্রতিটি পুনর্গঠনে এবং সম্ভাব্য প্রতিটি ফ্রেমের জন্য বরাদ্দ করা হবে:
@Composable fun LoadingWheelAnimation() { val animatedState = animateFloatAsState(/*...*/) LoadingWheel( // Creation and allocation of this modifier will happen on every frame of the animation! modifier = Modifier .padding(12.dp) .background(Color.Gray), animatedState = animatedState ) }
পরিবর্তে, আপনি মডিফায়ারের একই উদাহরণ তৈরি, নিষ্কাশন এবং পুনঃব্যবহার করতে পারেন এবং এটিকে কম্পোজেবলে পাস করতে পারেন:
// Now, the allocation of the modifier happens here: val reusableModifier = Modifier .padding(12.dp) .background(Color.Gray) @Composable fun LoadingWheelAnimation() { val animatedState = animateFloatAsState(/*...*/) LoadingWheel( // No allocation, as we're just reusing the same instance modifier = reusableModifier, animatedState = animatedState ) }
আনস্কোপড মডিফায়ার বের করা এবং পুনরায় ব্যবহার করা
সংশোধকগুলিকে একটি নির্দিষ্ট কম্পোজেবলে আনস্কোপ বা স্কোপ করা যেতে পারে। আনস্কোপড মডিফায়ারের ক্ষেত্রে, আপনি সহজ ভেরিয়েবল হিসাবে যেকোন কম্পোজেবলের বাইরে এগুলি সহজে বের করতে পারেন:
val reusableModifier = Modifier .fillMaxWidth() .background(Color.Red) .padding(12.dp) @Composable fun AuthorField() { HeaderText( // ... modifier = reusableModifier ) SubtitleText( // ... modifier = reusableModifier ) }
অলস লেআউটগুলির সাথে মিলিত হলে এটি বিশেষত উপকারী হতে পারে। বেশিরভাগ ক্ষেত্রে, আপনি চাইবেন আপনার সমস্ত, সম্ভাব্য তাৎপর্যপূর্ণ, আইটেমের পরিমাণে একই সংশোধক থাকুক:
val reusableItemModifier = Modifier .padding(bottom = 12.dp) .size(216.dp) .clip(CircleShape) @Composable private fun AuthorList(authors: List<Author>) { LazyColumn { items(authors) { AsyncImage( // ... modifier = reusableItemModifier, ) } } }
স্কোপড মডিফায়ার বের করা এবং পুনরায় ব্যবহার করা
নির্দিষ্ট কম্পোজেবলের জন্য স্কোপ করা সংশোধকগুলির সাথে কাজ করার সময়, আপনি সেগুলিকে সর্বোচ্চ সম্ভাব্য স্তরে বের করতে পারেন এবং যেখানে উপযুক্ত সেখানে পুনরায় ব্যবহার করতে পারেন:
Column(/*...*/) { val reusableItemModifier = Modifier .padding(bottom = 12.dp) // Align Modifier.Element requires a ColumnScope .align(Alignment.CenterHorizontally) .weight(1f) Text1( modifier = reusableItemModifier, // ... ) Text2( modifier = reusableItemModifier // ... ) // ... }
আপনার শুধুমাত্র এক্সট্রাক্ট করা, স্কোপড মডিফায়ারগুলি একই-স্কোপড, সরাসরি বাচ্চাদের কাছে পাঠানো উচিত। কেন এটি গুরুত্বপূর্ণ সে সম্পর্কে আরও রেফারেন্সের জন্য রচনায় স্কোপ সুরক্ষা বিভাগটি দেখুন:
Column(modifier = Modifier.fillMaxWidth()) { // Weight modifier is scoped to the Column composable val reusableItemModifier = Modifier.weight(1f) // Weight will be properly assigned here since this Text is a direct child of Column Text1( modifier = reusableItemModifier // ... ) Box { Text2( // Weight won't do anything here since the Text composable is not a direct child of Column modifier = reusableItemModifier // ... ) } }
নিষ্কাশিত মডিফায়ারের আরও চেইনিং
আপনি .then()
ফাংশনটি কল করে আপনার এক্সট্র্যাক্ট করা মডিফায়ার চেইনকে আরও চেইন বা যুক্ত করতে পারেন:
val reusableModifier = Modifier .fillMaxWidth() .background(Color.Red) .padding(12.dp) // Append to your reusableModifier reusableModifier.clickable { /*...*/ } // Append your reusableModifier otherModifier.then(reusableModifier)
শুধু মনে রাখবেন যে পরিবর্তনকারীর ক্রম গুরুত্বপূর্ণ!
আরও জানুন
আমরা তাদের পরামিতি এবং সুযোগ সহ পরিবর্তকগুলির একটি সম্পূর্ণ তালিকা প্রদান করি৷
সংশোধকগুলি কীভাবে ব্যবহার করতে হয় সে সম্পর্কে আরও অনুশীলনের জন্য, আপনি কম্পোজ কোডল্যাবে বেসিক লেআউটগুলিও দেখতে পারেন বা নাউ ইন অ্যান্ড্রয়েড রিপোজিটরিটি পড়ুন।
কাস্টম মডিফায়ার এবং কীভাবে সেগুলি তৈরি করতে হয় সে সম্পর্কে আরও তথ্যের জন্য, কাস্টম লেআউটের ডকুমেন্টেশনটি দেখুন - লেআউট মডিফায়ার ব্যবহার করে ।
{% শব্দার্থে %}আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলে লিঙ্ক টেক্সট প্রদর্শিত হয়
- লেআউট বেসিক রচনা করুন
- সম্পাদকের কাজ {:#editor-actions}
- কাস্টম লেআউট {:#custom-layouts }