Android 同级视图在可单击时防止recyclerview滚动
我的屏幕由一个有两个孩子的屏幕组成。一个孩子是一个RecyclerView,它占据了整个屏幕。另一个子元素是另一个ConstraintLayout,它包含一个TextView(屏幕实际上比这个更复杂,但我在这里将它简化为一些东西,以便更容易理解)。子ConstraintLayout位于RecyclerView上,并在滚动RecyclerView时向上滚动。这是使用RecyclerView上的滚动侦听器完成的,并重新调整子ConstraintLayout的Y位置。子约束窗口需要是可单击的 我遇到的问题是,如果您尝试通过首先触摸子ConstraintLayout来滚动RecyclerView,滚动将不起作用。但是,子ConstraintLayout的click事件处理程序将起作用 根据我对Android如何处理触摸事件的理解,如果一个视图在其onTouchEvent处理程序中返回false,该视图将不会收到任何进一步运动事件的通知。因此,理论上,如果我的孩子ConstraintLayout在其onTouchEvent处理程序中返回false,则RecyclerView仍应获取滚动运动事件 以下是我的布局xml:Android 同级视图在可单击时防止recyclerview滚动,android,android-recyclerview,Android,Android Recyclerview,我的屏幕由一个有两个孩子的屏幕组成。一个孩子是一个RecyclerView,它占据了整个屏幕。另一个子元素是另一个ConstraintLayout,它包含一个TextView(屏幕实际上比这个更复杂,但我在这里将它简化为一些东西,以便更容易理解)。子ConstraintLayout位于RecyclerView上,并在滚动RecyclerView时向上滚动。这是使用RecyclerView上的滚动侦听器完成的,并重新调整子ConstraintLayout的Y位置。子约束窗口需要是可单击的 我遇到的
<?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
}
}
}