Android 同级视图在可单击时防止recyclerview滚动

Android 同级视图在可单击时防止recyclerview滚动,android,android-recyclerview,Android,Android Recyclerview,我的屏幕由一个有两个孩子的屏幕组成。一个孩子是一个RecyclerView,它占据了整个屏幕。另一个子元素是另一个ConstraintLayout,它包含一个TextView(屏幕实际上比这个更复杂,但我在这里将它简化为一些东西,以便更容易理解)。子ConstraintLayout位于RecyclerView上,并在滚动RecyclerView时向上滚动。这是使用RecyclerView上的滚动侦听器完成的,并重新调整子ConstraintLayout的Y位置。子约束窗口需要是可单击的 我遇到的

我的屏幕由一个有两个孩子的屏幕组成。一个孩子是一个RecyclerView,它占据了整个屏幕。另一个子元素是另一个ConstraintLayout,它包含一个TextView(屏幕实际上比这个更复杂,但我在这里将它简化为一些东西,以便更容易理解)。子ConstraintLayout位于RecyclerView上,并在滚动RecyclerView时向上滚动。这是使用RecyclerView上的滚动侦听器完成的,并重新调整子ConstraintLayout的Y位置。子约束窗口需要是可单击的

我遇到的问题是,如果您尝试通过首先触摸子ConstraintLayout来滚动RecyclerView,滚动将不起作用。但是,子ConstraintLayout的click事件处理程序将起作用

根据我对Android如何处理触摸事件的理解,如果一个视图在其onTouchEvent处理程序中返回false,该视图将不会收到任何进一步运动事件的通知。因此,理论上,如果我的孩子ConstraintLayout在其onTouchEvent处理程序中返回false,则RecyclerView仍应获取滚动运动事件

以下是我的布局xml:

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout
    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:fitsSystemWindows="true"
    tools:background="#55338855">

    <androidx.constraintlayout.motion.widget.MotionLayout
        android:id="@+id/dashboardConstraintLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fitsSystemWindows="true"
        app:layoutDescription="@xml/dashboard_initial_animation_start"
        app:showPaths="false">

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/contentRecyclerView"
            android:layout_width="0dp"
            android:layout_height="0dp"
            android:clipChildren="false"
            android:fitsSystemWindows="true"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintStart_toEndOf="@id/guideWelcome"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintWidth_default="percent"
            app:layout_constraintWidth_percent="1.0" />

        <ReservationCard
            android:id="@+id/reservationConstraintLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginStart="16dp"
            android:layout_marginTop="60dp"
            android:layout_marginEnd="16dp"
            android:layout_marginBottom="16dp"
            android:background="@color/dashboard_reservation_card_background_color"
            android:padding="16dp"
            android:visibility="invisible"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@id/txtSearch">

            <TextView
                android:id="@+id/txtReservationHeader"
                style="@style/AppTheme.Label"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:text="@string/dashboard_screen_reservation_card_headline"
                android:textColor="@color/dashboard_reservation_card_text_color" />

        </com.sinnerschrader.motelone.screens.dashboard.ReservationCard>

    </androidx.constraintlayout.motion.widget.MotionLayout>

</androidx.coordinatorlayout.widget.CoordinatorLayout>

“child ConstraintLayout位于recyclerview上方,每当您滚动recyclerview时都会向上滚动”,因此您的子视图也会与recyclerview一起滚动?您面临的问题是,当您单击/聚焦“子视图”,然后滚动“回收器视图”时,它不起作用了?您可以共享一个屏幕截图/视频以更好地理解吗?子视图和“回收器视图”是兄弟。代码(未显示)允许子ConstraintLayout在recyclerview滚动时滚动(这是我想要的)。但我也希望孩子的约束是可点击的。我可以让代码做一个或另一个(滚动或可点击)。我没能让它同时做这两件事。在
onTouchEvent
中,如果(ev?.action==MotionEvent.action\u DOWN){gesturedector.onTouchEvent(ev)performClick()return false}你不需要在
onTouchEvent
中使用任何其他代码,我也看不到手势检测器的任何用途!
class ReservationCard : androidx.constraintlayout.widget.ConstraintLayout {

    constructor(context: Context?) : super(context)
    constructor(context: Context?, attrs: AttributeSet?) : super(context, attrs)
    constructor(context: Context?, attrs: AttributeSet?, defStyleAttr: Int) : super(context, attrs, defStyleAttr)

    private val gestureDetector: GestureDetector

    init {
        gestureDetector = GestureDetector(GestureListener())
    }

    override fun onTouchEvent(ev: MotionEvent?): Boolean {
        if (ev?.action == MotionEvent.ACTION_DOWN) {
            gestureDetector.onTouchEvent(ev)
            return true
        } else if (ev?.action == MotionEvent.ACTION_UP) {
            gestureDetector.onTouchEvent(ev)
            return false
        } else {
            super.onTouchEvent(ev)
            return false
        }
    }

    private inner class GestureListener : GestureDetector.OnGestureListener {
        override fun onFling(p0: MotionEvent?, p1: MotionEvent?, p2: Float, p3: Float): Boolean {
            return false
        }

        override fun onScroll(p0: MotionEvent?, p1: MotionEvent?, p2: Float, p3: Float): Boolean {
            return false
        }

        override fun onLongPress(p0: MotionEvent?) {
        }

        override fun onDown(p0: MotionEvent?): Boolean {
            return false
        }

        override fun onShowPress(p0: MotionEvent?) {
        }

        override fun onSingleTapUp(p0: MotionEvent?): Boolean {
            return false
        }
    }
}