জেটপ্যাক কম্পোজ Text -এ সূক্ষ্ম ইন্টারঅ্যাক্টিভিটি সক্ষম করে। টেক্সট সিলেকশন এখন আরও নমনীয় এবং এটি কম্পোজেবল লেআউট জুড়ে করা যায়। টেক্সট-এ ব্যবহারকারীর ইন্টারঅ্যাকশন অন্যান্য কম্পোজেবল লেআউট থেকে ভিন্ন, কারণ আপনি একটি Text কম্পোজেবলের কোনো অংশে মডিফায়ার যোগ করতে পারবেন না। এই পৃষ্ঠাটি সেই API-গুলো তুলে ধরে যা ব্যবহারকারীর ইন্টারঅ্যাকশন সক্ষম করে।
টেক্সট নির্বাচন করুন
ডিফল্টরূপে, কম্পোজেবলগুলো নির্বাচনযোগ্য নয়, যার মানে হলো ব্যবহারকারীরা আপনার অ্যাপ থেকে টেক্সট নির্বাচন এবং কপি করতে পারেন না। টেক্সট নির্বাচন সক্ষম করতে, আপনার টেক্সট এলিমেন্টগুলোকে একটি SelectionContainer কম্পোজেবলের মধ্যে র্যাপ করুন:
@Composable fun SelectableText() { SelectionContainer { Text("This text is selectable") } }

আপনি কোনো নির্বাচনযোগ্য এলাকার নির্দিষ্ট অংশে নির্বাচন নিষ্ক্রিয় করতে চাইতে পারেন। তা করার জন্য, আপনাকে অনির্বাচনযোগ্য অংশটিকে একটি DisableSelection কম্পোজেবলের মধ্যে রাখতে হবে:
@Composable fun PartiallySelectableText() { SelectionContainer { Column { Text("This text is selectable") Text("This one too") Text("This one as well") DisableSelection { Text("But not this one") Text("Neither this one") } Text("But again, you can select this one") Text("And this one too") } } }

LinkAnnotation ব্যবহার করে টেক্সটের ক্লিকযোগ্য অংশ তৈরি করুন
Text এর উপর ক্লিক শনাক্ত করতে, আপনি ‘ clickable মডিফায়ারটি যোগ করতে পারেন। তবে, আপনি হয়তো Text ভ্যালুর কোনো নির্দিষ্ট অংশের সাথে অতিরিক্ত তথ্য সংযুক্ত করতে চাইতে পারেন, যেমন কোনো নির্দিষ্ট শব্দের সাথে একটি URL জুড়ে দেওয়া যা ব্রাউজারে খোলা হবে। এই ধরনের ক্ষেত্রে, আপনাকে একটি LinkAnnotation ব্যবহার করতে হবে, যা টেক্সটের একটি ক্লিকযোগ্য অংশকে নির্দেশ করে।
LinkAnnotation সাহায্যে, আপনি একটি Text composable-এর কোনো অংশের সাথে একটি URL সংযুক্ত করতে পারেন, যা ক্লিক করলে স্বয়ংক্রিয়ভাবে খুলে যায়, যেমনটি নিম্নলিখিত কোড স্নিপেটে দেখানো হয়েছে:
@Composable fun AnnotatedStringWithLinkSample() { // Display multiple links in the text Text( buildAnnotatedString { append("Go to the ") withLink( LinkAnnotation.Url( "https://developer.android.com/", TextLinkStyles(style = SpanStyle(color = Color.Blue)) ) ) { append("Android Developers ") } append("website, and check out the") withLink( LinkAnnotation.Url( "https://developer.android.com/jetpack/compose", TextLinkStyles(style = SpanStyle(color = Color.Green)) ) ) { append("Compose guidance") } append(".") } ) }
Text কম্পোজেবলের কোনো অংশে ব্যবহারকারীর ক্লিকের প্রতিক্রিয়ায় আপনি একটি কাস্টম অ্যাকশনও কনফিগার করতে পারেন। নিম্নলিখিত কোড স্নিপেটে, যখন ব্যবহারকারী “জেটপ্যাক কম্পোজ”-এ ক্লিক করেন, তখন একটি লিঙ্ক প্রদর্শিত হয় এবং ব্যবহারকারী লিঙ্কটিতে ক্লিক করলে মেট্রিক্স লগ করা হয়:
@Composable fun AnnotatedStringWithListenerSample() { // Display a link in the text and log metrics whenever user clicks on it. In that case we handle // the link using openUri method of the LocalUriHandler val uriHandler = LocalUriHandler.current Text( buildAnnotatedString { append("Build better apps faster with ") val link = LinkAnnotation.Url( "https://developer.android.com/jetpack/compose", TextLinkStyles(SpanStyle(color = Color.Blue)) ) { val url = (it as LinkAnnotation.Url).url // log some metrics uriHandler.openUri(url) } withLink(link) { append("Jetpack Compose") } } ) }
আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলেও লিঙ্কের লেখা প্রদর্শিত হয়।
- কম্পোজে শব্দার্থবিদ্যা
- কম্পোজে অ্যাক্সেসযোগ্যতা
- কম্পোজে ম্যাটেরিয়াল ডিজাইন ২