CoordinatorLayout + FrameLayout + ViewPager + RecyclerView
Мое приложение:
Мой корневой макет имеет нижнюю панель навигации и каждый элемент NavigationBar
соответствует FrameLayout
который загружает фрагменты с ViewPager
s, которые также имеют несколько фрагментов с RecyclerView
s.
Я хочу реализовать CollapsingToolbarLayout
внутри моего корневого макета и когда RecyclerView
прокручивается в любом ViewPager
"s Fragment
s, я хочу свернуть панель инструментов
Моя проблема, я могу реализовать это поведение, когда ViewPager
это ребенок CoordinatorLayout
но не когда FrameLayout
это ребенок CoordinatorLayout
, Мне нужно реализовать FrameLayout
в противном случае я должен написать код панели инструментов в каждом BottomBar
макет фрагмента элемента.
Это мой корневой макет кода:
<?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:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.CoordinatorLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.design.widget.AppBarLayout
android:id="@+id/appBarLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#4DBC76"
app:elevation="0dp">
<android.support.design.widget.CollapsingToolbarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_scrollFlags="scroll|enterAlways">
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="60dp">
</android.support.constraint.ConstraintLayout>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginBottom="125dp"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:id="@+id/testRootFragment"
>
</FrameLayout>
</android.support.design.widget.CoordinatorLayout>
<bd.com.xbit.eat.bottom_navigation
android:id="@+id/bottomNavigationViewTest"
android:layout_width="match_parent"
android:layout_height="65dp"
app:elevation="25dp"
app:itemTextColor="@drawable/bottom_selector"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:menu="@menu/bottom_navigation" />
</android.support.constraint.ConstraintLayout>
Это мой код компоновки в viewpager, который находится во фрагменте, который вызывается в framelayout:
<android.support.v4.view.ViewPager
android:id="@+id/viewPager"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_below="@+id/talesTabLayout"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/talesTabLayout"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
А это мой RecyclerView
в пределах Fragment
макет:
<android.support.v7.widget.RecyclerView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/tales_all_recyclerView"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
>
</android.support.v7.widget.RecyclerView>
Я использовал "appbar_scrolling_view_behavior
"атрибут в Framelayout
, ViewPager
а также RecyclerView
без успеха. Я много гуглил, но не смог найти ссылки на этот конкретный вопрос. Любая помощь будет принята с благодарностью!
1 ответ
Использование app:layout_scrollFlags="scroll|exitUntilCollapsed"
за CollapsingToolbarLayout
сначала добиться правильного поведения.
Я хочу реализовать
CollapsingToolbarLayout
внутри моего корневого макета и когдаRecyclerView
прокручивается в любомViewPager
"sFragment
s, я хочу свернутьToolbar
,
Я не видел ни одного Toolbar
в вашем макете, однако, я предполагаю, что вы использовали его внутри AppBarLayout
и это поможет добиться того, чего вы хотите:
app:layout_scrollFlags="scroll|enterAlways"
- Добавить
Toolbar
в вашем корневом макете.
Моя проблема, я могу реализовать это поведение, когда
ViewPager
это ребенокCoordinatorLayout
но не когдаFrameLayout
это ребенокCoordinatorLayout
, Мне нужно реализоватьFrameLayout
в противном случае я должен написатьToolbar
код в каждомBottomBar
предметFragment
макет.
С помощью FrameLayout
в этой ситуации (вCoordinatorLayout
Кажется, это лучший выбор.
Однако я бы сделал что-то еще. Вместо добавления Fragment
внутри Fragment
или что-то еще, я бы вставил TabLayout
только под Toolbar
который содержит несколько Fragment
Это как мой пример: https://github.com/LinX64/AndroidSupportDesign-TabLayout
Вот как это должно быть разработано. Нет необходимости во взглядах друг на друга, это может вызвать проблемы.
Хороший дизайн с этими краями Кстати.