توفر مجموعة أدوات واجهة مستخدم Leanback بعض المكتبات الخاصة بالتلفزيون بشكل حصري
تطبيقات تم تطويرها لنظام التشغيل Android TV. وتشمل هذه المكتبات ما يلي:
مكتبة Leanback: توفر نماذج لواجهة مستخدم
يمكنك تبسيط عملية إنشاء تطبيقات Android TV.
يعمل التنقل داخل مجموعة أدوات واجهة المستخدم Leanback بالطريقة نفسها التي يعمل بها AndroidX
الصفحة 3، التي
تعمل على تبسيط إضافة صفحات
RecyclerView.Adapter
في مكتبة Leanback Paging، يكون المحول الظاهر عادةً
ObjectAdapter
بدلاً من ذلك، تتيح المكتبة إمكانية التنقّل بين الصفحات في ObjectAdapter.
لإضافة محوّل صفحات إلى تطبيقك، أضِف أولاً تبعية المكتبة إلى مشروعك:
ثم اتبع
مستندات الصفحة 3 باستخدام
androidx.leanback.paging.PagingDataAdapter بدلاً من
androidx.paging.PagingDataAdapter الاختلاف الوحيد هو أنه يمكنك الآن
لاجتياز Presenter
أو
PresenterSelector
تعمل هذه الميزة في أي مكان تستخدم فيه عادةً ObjectAdapter، مثل
ListRow:
توفر قوالب مجموعة أدوات واجهة مستخدم Leanback تنقلاً جانبيًا في
شاشة التصفّح لإضافة صف من علامات التبويب أفقيًا
عبر الجزء العلوي من التطبيق، يمكنك بدلاً من ذلك استخدام علامات تبويب Leanback بدلاً من ذلك.
بعد ذلك، نفِّذ علامات التبويب باستخدام LeanbackTabLayout وLeanbackViewPager من خلال
لمتابعة
دليل ViewPager لاحظ أن
تستند LeanbackViewPager إلى ViewPager، وليس ViewPager2.
تحتوي مكتبة علامات تبويب Leanback على قيود في المظاهر التي تتوافق معها وكيفية التركيز
الحركات.
المظاهر المتوافقة
المظاهر المشتقة من Theme.AppCompat هي فقط المتوافقة. TabLayout
يحتوي على قيد تنفيذ موضوع، ما يمنع أي موضوع غير تابع
من استخدام Theme.AppCompat. يمكنك أيضًا استخدام مظهر الجسر
مجموعة أدوات واجهة مستخدم Leanback.
التركيز على الانتقال من علامات التبويب إلى الأعلى
عندما يكون ارتفاع التخطيط أكبر من ارتفاع الشاشة، وتضغط على لوحة التحكّم
لأعلى، ينتقل عنصر التحكم مرة أخرى إلى علامة التبويب بدلاً من البقاء داخل الجزء
والانتقال إلى عنصر فوقه (انظر الشكل 1). لمعالجة هذه المشكلة، يمكن للمحتوى
داخل الجزء يجب أن يلغي تركيز البحث على سبيل المثال، استخدم
RowsSupportFragmentBrowseSupportFragment
داخل علامة تبويب، نظرًا لاحتوائها على طريقة بحث تركيز تم تجاوزها،
ويمنع التركيز من الرجوع إلى علامة التبويب.
الشكل 1. يؤدي النقر على زر السهم المتّجه للأعلى إلى نقل التركيز إلى علامة التبويب بدلاً من العنصر السابق.
يخضع كل من المحتوى وعيّنات التعليمات البرمجية في هذه الصفحة للتراخيص الموضحّة في ترخيص استخدام المحتوى. إنّ Java وOpenJDK هما علامتان تجاريتان مسجَّلتان لشركة Oracle و/أو الشركات التابعة لها.
تاريخ التعديل الأخير: 2025-07-27 (حسب التوقيت العالمي المتفَّق عليه)
[[["يسهُل فهم المحتوى.","easyToUnderstand","thumb-up"],["ساعَدني المحتوى في حلّ مشكلتي.","solvedMyProblem","thumb-up"],["غير ذلك","otherUp","thumb-up"]],[["لا يحتوي على المعلومات التي أحتاج إليها.","missingTheInformationINeed","thumb-down"],["الخطوات معقدة للغاية / كثيرة جدًا.","tooComplicatedTooManySteps","thumb-down"],["المحتوى قديم.","outOfDate","thumb-down"],["ثمة مشكلة في الترجمة.","translationIssue","thumb-down"],["مشكلة في العيّنات / التعليمات البرمجية","samplesCodeIssue","thumb-down"],["غير ذلك","otherDown","thumb-down"]],["تاريخ التعديل الأخير: 2025-07-27 (حسب التوقيت العالمي المتفَّق عليه)"],[],[],null,["# Leanback UI toolkit libraries\n\nBuild better with Compose \nCreate beautiful UIs with minimal code using Jetpack Compose for Android TV OS. \n[Compose for TV →](/training/tv/playback/compose) \n\nThe Leanback UI toolkit provides some TV-specific libraries exclusive to\napps developed for Android TV OS. These libraries include the following:\n\n- [Leanback](/training/tv/playback) library: provides UI templates that simplify creating Android TV apps.\n- [Leanback Preferences](/reference/androidx/leanback/preference/package-summary) library: provides preferences and settings screens that are consistent with the platform but can be themed to match your app.\n- [Leanback Paging](#leanback-paging-library) library: supports the AndroidX paging model for `ObjectAdapters`, which are commonly used with the Leanback templates.\n- [Leanback Tabs](#leanback-tabs-library) library: supports tabbed navigation on Android TV.\n\nLeanback paging library\n-----------------------\n\nPaging inside the Leanback UI toolkit works the same as the AndroidX\n[Paging 3](/topic/libraries/architecture/paging/v3-overview) library, which\nsimplifies adding paging to a\n[`RecyclerView.Adapter`](/reference/kotlin/androidx/recyclerview/widget/RecyclerView.Adapter).\nWith the Leanback Paging library, the adapter that is exposed is typically an\n[`ObjectAdapter`](/reference/kotlin/androidx/leanback/widget/ObjectAdapter)\ninstead, so the library adds paging support to `ObjectAdapter`.\n\nTo add a paging adapter to your app, first add the library dependency to your project: \n\n implementation \"androidx.leanback:leanback-paging:$version\"\n\nThen follow the\n[Paging 3 documentation](/topic/libraries/architecture/paging/v3-overview) using\n`androidx.leanback.paging.PagingDataAdapter` instead of\n`androidx.paging.PagingDataAdapter`. The only difference is that you're now able\nto pass in a [`Presenter`](/reference/kotlin/androidx/leanback/widget/Presenter)\nor\n[`PresenterSelector`](/reference/kotlin/androidx/leanback/widget/PresenterSelector).\nThis works anywhere you would ordinarily use an `ObjectAdapter`, such as in a\n[`ListRow`](/reference/kotlin/androidx/leanback/widget/ListRow): \n\n### Kotlin\n\n```kotlin\nval adapter: PagingDataAdapter\u003cMyItem\u003e = PagingDataAdapter(myPresenter,\n object : DiffUtil.ItemCallback\u003cMyItem\u003e() {\n override fun areItemsTheSame(\n oldItem: MyItem,\n newItem: MyItem\n ): Boolean {\n return oldItem.id === newItem.id\n }\n\n override fun areContentsTheSame(\n oldItem: MyItem,\n newItem: MyItem\n ): Boolean {\n return oldItem == newItem\n }\n })\n\nval header = HeaderItem(headerTitle)\nval row = ListRow(header, adapter)\n```\n\n### Java\n\n```java\nPagingDataAdapter\u003cMyItem\u003e adapter = new PagingDataAdapter(myPresenter, new DiffUtil.ItemCallback\u003cMyItem\u003e() {\n @Override\n public boolean areItemsTheSame(@NonNull MyItem oldItem, @NonNull MyItem newItem) {\n return oldItem.getId().equals(newItem.getId());\n }\n\n @Override\n public boolean areContentsTheSame(@NonNull MyItem oldItem, @NonNull MyItem newItem) {\n return oldItem.equals(newItem);\n }\n});\n\nHeaderItem header = new HeaderItem(headerTitle);\nRow row = new ListRow(header, adapter);\n```\n\nLeanback Tabs library\n---------------------\n\nThe Leanback UI toolkit templates provide side navigation in the\n[browse screen](/training/tv/playback/browse). To add a row of tabs horizontally\nacross the top of the app, you can instead use Leanback Tabs instead.\n\nAdd the library dependency to your project: \n\n implementation \"androidx.leanback:leanback-tab:$version\"\n\nThen implement tabs using `LeanbackTabLayout` and `LeanbackViewPager` by\nfollowing the existing\n[ViewPager guide](/guide/navigation/navigation-swipe-view). Note that\n`LeanbackViewPager` is based on `ViewPager`, not `ViewPager2`.\n\nThe following is an example: \n\n### Kotlin\n\n```kotlin\nval leanbackTabLayout = findViewById\u003cLeanbackTabLayout\u003e(R.id.tab_layout)\nval leanbackViewPager = findViewById\u003cLeanbackViewPager\u003e(R.id.view_pager)\n\nleanbackViewPager.setAdapter(adapter)\nleanbackTabLayout.setupWithViewPager(leanbackViewPager)\n```\n\n### Java\n\n```java\nLeanbackTabLayout leanbackTabLayout = findViewById(R.id.tab_layout);\nLeanbackViewPager leanbackViewPager = findViewById(R.id.view_pager);\n\nleanbackViewPager.setAdapter(adapter);\nleanbackTabLayout.setupWithViewPager(leanbackViewPager);\n```\n\n### Limitations\n\nThe Leanback Tabs library has limitations in the themes it supports and how focus\nmovement is handled.\n\n#### Supported themes\n\nOnly themes that are derived from `Theme.AppCompat` are supported. `TabLayout`\ncontains a theme enforcement constraint, which prevents any nondescendant theme\nof `Theme.AppCompat` from being used. You can also use the bridge theme for the\nLeanback UI toolkit.\n\n#### Focus movement from tabs to top\n\nWhen the layout height is greater than the screen height and you press the D-pad\nup button, control moves back to the tab instead of staying inside the fragment\nand navigating to an item above it (see figure 1). To handle this issue, contents\ninside the fragment must override focus search; for example, use\n[`RowsSupportFragment`](/reference/androidx/leanback/app/RowsSupportFragment).\n[`BrowseSupportFragment`](/reference/androidx/leanback/app/BrowseSupportFragment)\ncannot be used inside a tab as it has an overridden focus search method which\nprevents the focus from moving back to the tab.\n**Figure 1.** D-pad up button moves focus to tab instead of preceding item."]]