تفعيل تفاعلات المستخدم

يتيح Jetpack Compose تفاعلًا دقيقًا في Text. أصبح اختيار النص أكثر مرونة ويمكن تنفيذه في التنسيقات القابلة للتجميع. تختلف تفاعلات المستخدمين في النص عن التنسيقات الأخرى القابلة للتجميع، لأنّه لا يمكنك إضافة مُعدِّل إلى جزء من عنصر Text قابل للتجميع. تُبرز هذه الصفحة واجهات برمجة التطبيقات التي تتيح تفاعلات المستخدمين.

تحديد نص

لا يمكن اختيار العناصر القابلة للتجميع تلقائيًا، ما يعني أنّه لا يمكن للمستخدمين اختيار النص من تطبيقك ونسخه. لتفعيل اختيار النص، عليك لف عناصر النص بعنصر قابل للتجميع 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")
        }
    }
}

فقرة نصية أطول حاول المستخدم اختيار المقطع بأكمله، ولكن بما أنّه تم تطبيق DisableSelection على سطرَين، لم يتم اختيارهما.

إنشاء أقسام نصية يمكن النقر عليها باستخدام LinkAnnotation

للاستماع إلى النقرات على Text، يمكنك إضافة المُعدِّل clickable. ومع ذلك، قد تحتاج إلى إرفاق معلومات إضافية بجزء معيّن من قيمة Text، مثل عنوان URL مرفق بكلمة معيّنة ليتم فتحه في أحد المتصفحات. في مثل هذه الحالات، عليك استخدام LinkAnnotation، وهو تعليق توضيحي يمثّل جزءًا من النص يمكن النقر عليه.

باستخدام LinkAnnotation، يمكنك إرفاق عنوان URL بجزء من Text قابل للتركيب يفتح تلقائيًا بعد النقر عليه، كما هو موضّح في المقتطف التالي:

يمكنك أيضًا ضبط إجراء مخصّص استجابةً للنقر الذي يُجريه المستخدم على جزء من العنصر القابل للتجميع Text. في المقتطف التالي، عندما ينقر المستخدم على "Jetpack Compose"، يتم عرض رابط ويتم تسجيل المقاييس إذا صعَّد المستخدم النقر على الرابط: