图片合拢时,NestedScrollView中的RecyclerView无法向上滚动

时间:2018-06-23 20:04:19

标签: android android-recyclerview material-design android-appbarlayout android-collapsingtoolbarlayout

以下是整个项目的链接,以便您可以重现问题: https://github.com/FaridArbai/TapExchange/tree/master/TapExchange

我想为我一直在苦苦挣扎约两天的问题寻求帮助,尽管我进行了深入的研究,但仍未找到解决方案。

基本上,我有一个内部带有CollapsingToolbarLayout的AppBarLayout,其任务是当用户向下滚动CardViews的RecyclerView时折叠背景图像。当图像完全折叠后,当我尝试向下滚动该RecyclerView时,就会出现问题:如果我触摸组成RecyclerView的卡片视图之一,它将无法滚动!

这是没有塌陷的外观(这里我可以毫无问题地滚动):

Uncollapsed Image, able to scroll in any direction

这是图像折叠后的外观(如果我的手指触摸构成RecyclerView的任何Cardview,则无法向下滚动)

Collapsed Image, unable to scroll down if I touch one of the cardviews

整个布局的代码:

    <?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".profiles.PersonalProfile"
    android:background="#FCFCFC">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/personal_appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/personal_collapsing"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:layout_scrollFlags="scroll|exitUntilCollapsed|snap"
            app:contentScrim="?attr/colorPrimary"
            app:title=""
            app:titleEnabled="false">

            <ImageView
                android:id="@+id/personal_image_background"
                android:layout_width="match_parent"
                android:layout_height="340dp"
                android:scaleType="centerCrop"
                android:src="@drawable/profile_background"/>

            <android.support.v7.widget.Toolbar 
                android:id="@+id/personal_toolbar"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
                app:layout_collapseMode="pin"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:title="">

                <LinearLayout
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:orientation="horizontal">
                    <Space
                        android:id="@+id/avatar_collapsed_target"
                        android:layout_width="40dp"
                        android:layout_height="40dp"
                        android:layout_marginLeft="0dp"/>

                    <TextView
                        android:id="@+id/personal_title"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:textSize="18dp"
                        android:layout_gravity="center"
                        android:layout_marginLeft="10dp"
                        android:text="Unknown Username"/>
                </LinearLayout>

            </android.support.v7.widget.Toolbar>

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


    <android.support.design.widget.FloatingActionButton
        android:id="@+id/section_selection_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|end"
        android:layout_margin="@dimen/fab_margin"
        app:srcCompat="@drawable/ic_action_add" />


    <de.hdodenhof.circleimageview.CircleImageView
        android:id="@+id/personal_image_foreground"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_marginTop="120dp"
        android:layout_gravity="top|center_horizontal"
        android:src="@drawable/executive"
        app:collapsedTarget="@id/avatar_collapsed_target"
        app:layout_behavior="com.faridarbai.tapexchange.graphical.CollapsingAvatarBehavior"
        android:elevation="5dp"/>

    <LinearLayout
        android:id="@+id/personal_status"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_anchor="@id/personal_image_foreground"
        app:layout_anchorGravity="bottom|center"
        android:paddingTop="30dp">

        <TextView
            android:id="@+id/username_status"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Unknown Username"
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" />
    </LinearLayout>

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

        <android.support.v7.widget.RecyclerView
            android:id="@+id/personal_sections_view"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:padding="0dp" />

    </android.support.v4.widget.NestedScrollView>

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

我正在使用API​​ 25构建并使用版本25.4.0中的GUI实用程序。如果有人可以帮助,我将非常感激。

谢谢

编辑

我尝试使用SDK n°27和27.1.1构建工具,同时抑制了“ snap”和NestedScrollView并仍然遇到相同的问题:背景图像折叠后,如果我最初将手指放在手指上,RecyclerView将无法向上滚动在RecyclerView的CardView上。这很奇怪,因为WhatsApp,Facebook和Telegram使用非常相似的Layout,并且它们没有此问题,因此应该进行周密的解决。

有人帮忙吗?

1 个答案:

答案 0 :(得分:0)

为什么在NestedScrollView中使用RecyclerView ?!如果您有更多具有不同布局的项目,则可以使用具有不同ViewType的recyclerView,但是我不建议在NestedScrollView中使用它,请尝试直接使用它,并且不要忘记将此app:layout_behavior="@string/appbar_scrolling_view_behavior"放在recylerView中,它将工作。