CoordinatorLayout + FrameLayout + ViewPager + RecyclerView - PullRequest
0 голосов
/ 13 сентября 2018

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

enter image description here У моего корневого макета есть нижняя панель навигации, и каждый элемент NavigationBar соответствует FrameLayout, который загружает фрагменты с ViewPager с, которые также имеют несколько фрагментов с RecyclerView с.

Я хочу реализовать CollapsingToolbarLayout внутри моего корневого макета, и когда RecyclerView прокручивается в пределах любого ViewPager * 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>

Это код компоновки моего видового экрана, который находится во фрагменте, который вызывается в 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 Ответ

0 голосов
/ 14 сентября 2018

Сначала используйте app:layout_scrollFlags="scroll|exitUntilCollapsed" для CollapsingToolbarLayout, чтобы добиться правильного поведения.

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

Я не увидел Toolbar s в вашем макете, однако, я предполагаю, что вы использовали его внутри AppBarLayout и это поможет достичь того, что вы хотите:

app:layout_scrollFlags="scroll|enterAlways"
  • Добавьте Toolbar в корневой макет.

Моя проблема в том,Я могу реализовать это поведение, когда ViewPager является дочерним по отношению к CoordinatorLayout, но не когда FrameLayout является дочерним по отношению к CoordinatorLayout.Мне нужно реализовать FrameLayout, в противном случае мне нужно написать Toolbar код в каждом элементе BottomBar Fragment.

Использование FrameLayout в этой ситуации ( В CoordinatorLayout), кажется, лучший выбор.


Однако, Я бы сделал что-то еще.Вместо добавления Fragment s внутри Fragment или чего-либо другого, я бы вставил TabLayout прямо под Toolbar, который содержит несколько Fragment s, как мой пример: https://github.com/LinX64/AndroidSupportDesign-TabLayout

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

Кстати, приятный дизайн с этими краями.

...