Vertical RecyclerView会对嵌套的Horizo​​ntal RecyclerView上的滚动做出反应

时间:2017-06-22 13:59:04

标签: android android-recyclerview nestedrecyclerview

enter image description here

在我的活动中,我有ViewPager由片段组成。我已使用CustomViewPager禁用了ViewPager上的滑动动作。

我的片段布局有Vertical RecyclerView,在这个RecyclerView里面有多个Horizo​​ntal RecyclerViews。

为了确保我的AppBarLayout正确响应滚动行为,我在每个Horizo​​ntal RecyclerView上以编程方式将nestedScrollingEnabled设置为false。

P.S。我使用recylerview版本25.4.0

问题就像你在上面的gif中看到的那样,滚动水平回收视图时触摸应该是完全侧向的,即使在水平回收视图上略微倾斜运动,垂直Recyclerview也会选择该事件并垂直向上滚动页面和放大器;下。如何解决这个问题?

CustomViewPager.java

public class CustomViewPager extends ViewPager {

    private boolean enabled;

    public CustomViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
        this.enabled = true;
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        if (this.enabled) {
            return super.onTouchEvent(event);
        }

        return false;
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent event) {
        if (this.enabled) {
            return super.onInterceptTouchEvent(event);
        }

        return false;
    }

    public void setPagingEnabled(boolean enabled) {
        this.enabled = enabled;
    }
}

片段布局

<android.support.v7.widget.RecyclerView
    android:id="@+id/recyclerview_productoverview"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/windowBackground"/>

recyclerview_productoverview(Vertical RecyclerView)中的项目布局

<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="wrap_content">

    <android.support.constraint.ConstraintLayout
        android:id="@+id/layout_section_header"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="0dp"
        android:background="#ebedff"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <experttag.nurserylive.util.ui.widget.WhitneySemiBoldTextView
            android:id="@+id/textview_item_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="16dp"
            android:text="TOP FEATURED"
            android:textColor="#3f4266"
            android:textSize="16sp"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintBottom_toBottomOf="parent"
            android:layout_marginBottom="16dp"
            app:layout_constraintVertical_bias="0.19"
            android:layout_marginLeft="16dp"
            app:layout_constraintLeft_toLeftOf="parent"
            android:layout_marginRight="16dp"
            app:layout_constraintRight_toRightOf="parent"/>

        <experttag.nurserylive.util.ui.widget.WhitneySemiBoldTextView
            android:id="@+id/textview_item_viewall"
            style="@style/AppTheme.TextLink"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="#3f4266"
            android:text="@string/btn_view_all_caps"
            android:layout_marginRight="16dp"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintBaseline_toBaselineOf="@+id/textview_item_name"/>
    </android.support.constraint.ConstraintLayout>

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerview_item_section"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/layout_section_header"/>

</android.support.constraint.ConstraintLayout>

Horizo​​ntal RecyclerView:@ id / recyclerview_item_section

1 个答案:

答案 0 :(得分:1)

使用BetterRecyclerView

解决了这个问题

see demo

read explanation

BetterRecyclerView.java