Первое - это основная ошибка новичка - использовать OnClickListener в onBindViewHolder. Воспользуйтесь моим решением, которое решит вашу проблему и бонус: избавит вас от утечек памяти.
1) Создайте этот класс:
public class RecyclerTouchListener implements RecyclerView.OnItemTouchListener {
private OnItemClickListener mListener;
public interface OnItemClickListener {
public void onItemClick(View view, int position);
public void onLongItemClick(View view, int position);
}
GestureDetector mGestureDetector;
public RecyclerTouchListener(Context context, final RecyclerView recyclerView, OnItemClickListener listener) {
mListener = listener;
mGestureDetector = 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 && mListener != null) {
mListener.onLongItemClick(child, recyclerView.getChildAdapterPosition(child));
}
}
});
}
@Override public boolean onInterceptTouchEvent(RecyclerView view, MotionEvent e) {
View childView = view.findChildViewUnder(e.getX(), e.getY());
if (childView != null && mListener != null && mGestureDetector.onTouchEvent(e)) {
mListener.onItemClick(childView, view.getChildAdapterPosition(childView));
return true;
}
return false;
}
@Override public void onTouchEvent(RecyclerView view, MotionEvent motionEvent) { }
@Override
public void onRequestDisallowInterceptTouchEvent (boolean disallowIntercept){}
}
2) Присоедините его к вашему RecyclerView:
yourRecyclerView.addOnItemTouchListener(new RecyclerTouchListener(context, yourRecyclerView, new RecyclerTouchListener.OnItemClickListener() {
@Override
public void onItemClick(View view, int position) {
//do some work
}
@Override
public void onLongItemClick(View view, int position) {
//do some work
}
}));
Удачи!