我有一个布局,其中RecyclerView位于具有几个按钮的另一个布局之上。第一个回收商项目是一个带有较大上边距的标题,以在其上方创建一个空白区域。现在我希望点击通过该开放空间工作,刷卡也应该滚动回收器。视图位于一个简单的框架中。
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<package.FeedBackgroundView
android:id="@+id/feed_background"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:scrollbars="vertical"/>
</FrameLayout>
回收者仅使用顶部填充或边距消耗所有点击。我需要点击才能通过,但是滑动应该留在回收站中进行滚动。
编辑:
我点击了工作,解决方案是:
recycler.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
background.dispatchTouchEvent(event);
return false;
}
});
现在我遇到了一个问题,因为我翻译了背景(视差),点击次数并没有到达正确的位置。我是否也必须翻译这些活动?
答案 0 :(得分:3)
好的,我解决了这两个问题。
recycler.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
MotionEvent e = MotionEvent.obtain(event);
Matrix m = new Matrix();
m.setTranslate(0f, -backgroundTranslation);
e.transform(m);
background.dispatchTouchEvent(e);
e.recycle();
return false;
}
});
这复制了回收者触摸事件和&#34;修复&#34;它的位置。翻译是翻译为背景。
答案 1 :(得分:0)
通过已解决的解决方案,似乎发送的触摸事件似乎并不总是有效。它的行为好像有一个0的触摸斜率。我认为正在发生的事情是当发生requestDisallowInterceptTouchEvent(true);
事件时,RecyclerView正在调用ACTION_MOVE
导致间歇性行为。
相反,我得到了更好的结果:
recycler.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
return background.dispatchTouchEvent(event);
}
});
答案 2 :(得分:0)
以下是RecyclerView项目点击
的一些最佳解决方案RecyclerView rvQueues = (RecyclerView) findViewById(R.id.rvQueues);
`rvQueues.addOnItemTouchListener(
new RecyclerItemClickListener(mActivity, rvQueues, new RecyclerItemClickListener.OnItemClickListener() {
@Override
public void onItemClick(View view, int position) {
//TODO do your stuff
}
@Override
public void onLongItemClick(View view, int position) {
//TODO do your stuff
}
})
);
import android.content.Context; import android.support.v7.widget.RecyclerView; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.View;
public class RecyclerItemClickListener implements RecyclerView.OnItemTouchListener {
private OnItemClickListener itemClickListener;
public interface OnItemClickListener {
public void onItemClick(View view, int position);
public void onLongItemClick(View view, int position);
}
private GestureDetector gestureDetector;
public RecyclerItemClickListener(Context context, final RecyclerView recyclerView, OnItemClickListener listener) {
itemClickListener = listener;
gestureDetector = new GestureDetector(context, new GestureDetector.SimpleOnGestureListener() {
@Override
public boolean onSingleTapUp(MotionEvent e) {
return true;
}
@Override
public void onLongPress(MotionEvent e) {
View child = recyclerView.findChildViewUnder(e.getX(), e.getY());
if (child != null && itemClickListener != null) {
itemClickListener.onLongItemClick(child, recyclerView.getChildAdapterPosition(child));
}
}
});
}
@Override
public boolean onInterceptTouchEvent(RecyclerView view, MotionEvent e) {
View mChildView = view.findChildViewUnder(e.getX(), e.getY());
if (mChildView != null && itemClickListener != null && gestureDetector.onTouchEvent(e)) {
itemClickListener.onItemClick(mChildView, view.getChildAdapterPosition(mChildView));
return true;
}
return false;
}
@Override
public void onTouchEvent(RecyclerView view, MotionEvent motionEvent) {
}
@Override
public void onRequestDisallowInterceptTouchEvent(boolean disallowIntercept) {
}
}