很久没更文章了。
其实一直想更,但是觉得不知道Android方面要写什么(PS,最近有点着迷微信小程序,之后可能会更一些小程序的文章)。
说回正题,毕竟双十一了,毕竟特朗普都当选总统了,毕竟乐视股价都打开丅行空间了,毕竟刚刚经历了一些事。。。
毕竟毕竟,是要更一篇文章了。
今天的主题来说说RecyclerView的点击事件.通过两种方法实现
第一种:通过实现OnItemTouchListener。
第二种:通过设置回调。
众所周知,RecyclerView的延展性远远强于ListView和GridView,但是美中不足的是,官方并没有给它设置OnItemClick事件,官方不做自然有官方的用意,但是我们开发经常要用到啊。
首先是,第一种实现方法
代码主角:
1、RecyclerView.Adapter类
//其实直接在外部定义好下面这个类,一本万利的调用就好
public class RecyclerItemClickListener implements RecyclerView.OnItemTouchListener {
public interface OnItemClickListener {
void onItemClick(View view, int position);
void onItemLongClick(View view, int position);
}
private OnItemClickListener mListener;
private GestureDetector mGestureDetector;
public RecyclerItemClickListener(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 childView = recyclerView.findChildViewUnder(e.getX(), e.getY());
if (childView != null && mListener != null) {
mListener.onItemLongClick(childView, recyclerView.getChildAdapterPosition(childView));
}
}
});
}
@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 false;
}
@Override
public void onTouchEvent(RecyclerView view, MotionEvent motionEvent) {
}
@Override
public void onRequestDisallowInterceptTouchEvent(boolean disallowIntercept) {
}
}
其实第一种方法最省事,只需要在外部定义好这个类。
然后,在需要调用的地方,写具体的方法逻辑就OK了。基本就是Ctrl + c ,Ctrl + v的模式
mRecyclerView.setAdapter(mAdapter);
//加入Item点击事件
mRecycler.addOnItemTouchListener(new RecyclerItemClickListener(context, mRecycler, new RecyclerItemClickListener.OnItemClickListener() {
@Override
public void onItemClick(View view, int position) {
ToastUtil.showMessage(context, "position = " + position);
}
@Override
public void onItemLongClick(View view, int position) {
ToastUtil.showMessage(context, "long position = " + position);
}
}));
我最喜欢用这种方式啦,stackOverFlow上挖来的,在之前一直用回调的方法,写多了有点累
然后是,第二种实现方法:
代码主角:
1、RecyclerView.Adapter类 (重写的方法就不多说了,只说重点,也就是,回调)
首先,简单的回调三部曲:
//回调三部曲
//1.声明一个接口,定义一个回调方法
public interface OnMyClickListener {
void OnMyClick(View view, int pos);
}
//2.私有化这个接口
private OnMyClickListener mListener;
//3.暴露一个方法给外部,把私有的这个接口,通过外来赋值初始化
public void setOnMyClickListener(OnMyClickListener listener) {
this.mListener = listener;
}
其次, 在需要响应点击事件的地方,植入该接口的回调方法:
//一般是在onBindViewHolder里设置
public void onBindViewHolder(final MyViewHolder holder, final int pos) {
//以Button举例
holder.mButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//将自己的回调方法放在此处,
mListener.OnMyClicklick(holder, position);
}
});
最后,只要在Activity中实现该接口,进行调用就好啦
/**
*简单写
*/
//在Activity中实现之前声明的接口OnMyClickListener
public class XXXActivity extends BaseActivity implements XXXAdapter.OnMyClickListener {
//私有化
private ListView mListView;
private ArrayList<StoreMenu> list = new ArrayList<>();
private XXXAdapter mAdapter;
protected void onCreate(Bundle savedInstanceState) {
.
.
.
mAdapter = new XXXAdapter(this, list);
//注意,这里是在Adapter中调用我们定义的接口
mAdapter.setOnMyClickListener(this);
mListView.setAdapter(mAdapter);
}
//重写该接口,里面写具体需要实现的业务逻辑
@Override
public void OnMyAddClick(View view, final int pos) {
//这里写需要实现的业务逻辑
}
}
大功告成。
好久没写,若有纰漏,多多包涵。