Вам не нужно ViewPager
для работы с BottomNavigation
и новым компонентом архитектуры навигации.Я работал в образце приложения, которое использует ровно два, см. здесь .
Основная концепция заключается в следующем: у вас есть основное действие, в котором будет размещаться BottomNavigationView
, и этоузел навигации для вашего графика навигации, вот как выглядит его XML:
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".main.MainActivity">
<fragment
android:id="@+id/my_nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="0dp"
app:defaultNavHost="true"
app:layout_constraintBottom_toTopOf="@+id/navigation"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/nav_graph" />
<android.support.design.widget.BottomNavigationView
android:id="@+id/navigation"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="0dp"
android:layout_marginEnd="0dp"
android:background="?android:attr/windowBackground"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:menu="@menu/navigation" />
</android.support.constraint.ConstraintLayout>
Меню навигации (меню вкладок) дляBottomNavigationView
выглядит следующим образом:
navigation.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/navigation_home"
android:icon="@drawable/ic_home"
android:title="@string/title_home" />
<item
android:id="@+id/navigation_people"
android:icon="@drawable/ic_group"
android:title="@string/title_people" />
<item
android:id="@+id/navigation_organization"
android:icon="@drawable/ic_organization"
android:title="@string/title_organization" />
<item
android:id="@+id/navigation_business"
android:icon="@drawable/ic_business"
android:title="@string/title_business" />
<item
android:id="@+id/navigation_tasks"
android:icon="@drawable/ic_dashboard"
android:title="@string/title_tasks" />
</menu>
Все это всего лишь настройка BottomNavigationView
.Теперь, чтобы заставить его работать с компонентом Navigation Arch, вам нужно зайти в редактор навигационных графиков, добавить все места назначения фрагментов (в моем случае у меня их 5, по одному для каждой вкладки) и установить идентификатор пункта назначения с тем жеимя в файле navigation.xml
:
![enter image description here](https://i.stack.imgur.com/7RtUx.png)
Это заставит android сделать ссылку между вкладкой и фрагментом, теперь каждый разпользователь нажимает на вкладку «Домой», android позаботится о загрузке нужного фрагмента.Существует также один фрагмент кода kotlin, который необходимо добавить в NavHost (основное действие), чтобы связать вещи с BottomNavigationView
:
, который необходимо добавить в свой onCreate:
bottomNavigation.setupWithNavController(Navigation.findNavController(this, R.id.my_nav_host_fragment))
Это говорит Android, чтобы сделать проводку между компонентом архитектуры навигации и BottomNavigationView.Подробнее см. В документах .
Чтобы получить такой же режим поведения, как и при использовании youtube, просто добавьте:
navigation.setOnNavigationItemSelectedListener {item ->
onNavDestinationSelected(item, Navigation.findNavController(this, R.id.my_nav_host_fragment))
}
Это заставит пункты назначения войти вbackstack, поэтому, когда вы нажмете кнопку «Назад», появится последний посещенный пункт назначения.