CoordinatorLayout + FrameLayout + ViewPager + RecyclerView

Мое приложение:

Мой корневой макет имеет нижнюю панель навигации и каждый элемент NavigationBar соответствует FrameLayout который загружает фрагменты с ViewPagers, которые также имеют несколько фрагментов с RecyclerViews.

Я хочу реализовать CollapsingToolbarLayout внутри моего корневого макета и когда RecyclerView прокручивается в любом ViewPager"s Fragments, я хочу свернуть панель инструментов

Моя проблема, я могу реализовать это поведение, когда 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"s Fragments, я хочу свернуть 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

Вот как это должно быть разработано. Нет необходимости во взглядах друг на друга, это может вызвать проблемы.

Хороший дизайн с этими краями Кстати.