Android 使用RecyclerView滚动协调器布局中的某些视图

Android 使用RecyclerView滚动协调器布局中的某些视图,android,android-recyclerview,android-coordinatorlayout,android-appbarlayout,Android,Android Recyclerview,Android Coordinatorlayout,Android Appbarlayout,您好,我与AppBar、工具栏和RecyclerView有CoordinatorLayout <?xml version="1.0" encoding="utf-8"?> <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android

您好,我与
AppBar
工具栏
RecyclerView
CoordinatorLayout

<?xml version="1.0" encoding="utf-8"?>    
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true">

<android.support.design.widget.AppBarLayout
    android:id="@+id/appbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:elevation="0dp"
    android:fitsSystemWindows="true"
    app:elevation="0dp">

    <android.support.v7.widget.Toolbar
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:elevation="8dp"
        android:fitsSystemWindows="true"
        app:contentInsetEnd="0dp"
        app:contentInsetStart="0dp"/>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_scrollFlags="scroll|exitUntilCollapsed"/>

</android.support.design.widget.AppBarLayout>

<android.support.v7.widget.RecyclerView
    android:id="@+id/rv_photos"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:nestedScrollingEnabled="false"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
</android.support.design.widget.CoordinatorLayout>

我想将
工具栏
保留在顶部,不想移动它,但让
线性布局
在其下方滚动(在
工具栏
下)

我还发现RecyclerView不支持协调器布局。它不会触发AppBar滚动事件。如果我将它包装在NestedSCrollView中,它会工作,但RecyclerView不是循环视图持有者,所以它对我不起作用

有人能帮我做到这一点吗?

像这样试试

   ...
    </android.support.design.widget.AppBarLayout>

     <android.support.v4.widget.NestedScrollView
                            android:layout_width="match_parent"
                            android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

            <android.support.v7.widget.RecyclerView
                android:id="@+id/rv_photos"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:nestedScrollingEnabled="false"
                app:layout_behavior="@string/appbar_scrolling_view_behavior"
                />
</android.support.v4.widget.NestedScrollView>
。。。
像这样试试

   ...
    </android.support.design.widget.AppBarLayout>

     <android.support.v4.widget.NestedScrollView
                            android:layout_width="match_parent"
                            android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

            <android.support.v7.widget.RecyclerView
                android:id="@+id/rv_photos"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:nestedScrollingEnabled="false"
                app:layout_behavior="@string/appbar_scrolling_view_behavior"
                />
</android.support.v4.widget.NestedScrollView>
。。。

将工具栏和线性布局放在一个适当的位置。然后使用适当的折叠模式属性。例如,您可以对工具栏使用
pin
,对线性布局使用
parallax

<android.support.design.widget.AppBarLayout>
    <android.support.design.widget.CollapsingToolbarLayout
        ...
        app:layout_scrollFlags="scroll|exitUntilCollapsed">

        <android.support.v7.widget.Toolbar
            ...
            app:layout_collapseMode="pin"/>

        <LinearLayout
            ...
            app:layout_collapseMode="parallax"/>

    </android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>

将工具栏和线性布局置于。然后使用适当的折叠模式属性。例如,您可以对工具栏使用
pin
,对线性布局使用
parallax

<android.support.design.widget.AppBarLayout>
    <android.support.design.widget.CollapsingToolbarLayout
        ...
        app:layout_scrollFlags="scroll|exitUntilCollapsed">

        <android.support.v7.widget.Toolbar
            ...
            app:layout_collapseMode="pin"/>

        <LinearLayout
            ...
            app:layout_collapseMode="parallax"/>

    </android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>

我无法以所描述的方式实现它。RecyclerView不会将滚动事件发送到AppaBar布局(这真的很奇怪),所以我需要分割屏幕上的每个视图,并使RecyclerView适配器在一个RecyclerView中处理它们。谢谢大家的回答和花在这上面的时间

我无法以描述的方式实现它。RecyclerView不会将滚动事件发送到AppaBar布局(这真的很奇怪),所以我需要分割屏幕上的每个视图,并使RecyclerView适配器在一个RecyclerView中处理它们。谢谢大家的回答和花在这上面的时间

嗨!这样,RecyclerView将不会回收视图持有者,所以它对我不起作用。我已经试过了。无论如何,谢谢你的回答和时间:)嗨!这样,RecyclerView将不会回收视图持有者,所以它对我不起作用。我已经试过了。无论如何,谢谢你的回答和时间:)你好!我已经试过了。我需要将我的线性布局放置在工具栏下方,在您的示例中,它将与工具栏重叠。同样,Realver视图没有触发AppBar滚动事件。@ OlexiiMuraviov,在这种情况下,您可能需要考虑以下选项之一:1。使用操作栏而不是标题栏,并将线性布局仅放在折叠工具栏中(此活动使用带有操作栏的主题)。2.使线性布局成为回收器视图3的第一项。为工具栏和线性布局定义自定义行为(对此不确定)您好!我已经试过了。我需要将我的线性布局放置在工具栏下方,在您的示例中,它将与工具栏重叠。同样,Realver视图没有触发AppBar滚动事件。@ OlexiiMuraviov,在这种情况下,您可能需要考虑以下选项之一:1。使用操作栏而不是标题栏,并将线性布局仅放在折叠工具栏中(此活动使用带有操作栏的主题)。2.使线性布局成为回收器视图3的第一项。定义工具栏和线性布局的自定义行为(对此不确定)