RecyclerView.Adapter封装,包括点击监听,长按监听,继承时不需要重新设置

本文介绍了一个自定义的RecyclerView.Adapter实现,包括ViewHolder的封装,并提供了点击和长按事件接口。通过继承BaseRecyclerAdapter类,可以轻松地为项目定制适配器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自己封装个RecyclerView.Adapter,自己的才是最好的,恩,直接上代码:
1.首先是RecyclerView的ViewHolder:

import android.support.v7.widget.RecyclerView.ViewHolder;
import android.view.View;

/**
 * RecyclerView.ViewHolder万能
 * Created by ruin
 */
public abstract class BaseViewHolder extends ViewHolder {
    public View itemView;

    public BaseViewHolder(View view) {
        super(view);
        itemView = view;
    }
}

大家发现我在封装这个的时候加了个itemView,别困惑~别着急~后面会解释干什么用的~

2.然后我们来封装Adapter

import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import java.util.LinkedList;
import java.util.List;

/**
 * RecyclerAdapter 封装类
 * Created by ruin
 */
public abstract class BaseRecyclerAdapter<T> extends RecyclerView.Adapter<BaseViewHolder> {
    protected Context context;
    protected LayoutInflater inflater;
    protected List<T> mDatas = new LinkedList<T>();
    public OnItemClickListener<T> onItemClickListener;
    public OnItemLongClickListener<T> onItemLongClickListener;

    public BaseRecyclerAdapter(Context context) {
        this.context = context;
        inflater = LayoutInflater.from(context);
    }


    @Override
    public int getItemCount() {
        return mDatas == null ? 0 : mDatas.size();
    }

    public T getItem(int position) {

        return mDatas.get(position);
    }

    public void addAll(List<T> datas) {
        mDatas.addAll(datas);
        notifyDataSetChanged();
    }

    public void addItemTop(List<T> datas) {
        mDatas = datas;
    }

    public void remove(int position) {
        mDatas.remove(position);
        notifyDataSetChanged();
    }

    public void clear() {
        mDatas.clear();
        notifyDataSetChanged();
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    public List<T> getDatas() {
        return mDatas;
    }

    @Override
    public BaseViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        return getHolder(parent, viewType);
    }

    @Override
    public void onBindViewHolder(BaseViewHolder holder, final int position) {
    //还记得么~上面的itemView~用在这里啦
        holder.itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (onItemClickListener != null) {
                    onItemClickListener.onItemClick(v, position, getItem(position));
                }
            }
        });
        holder.itemView.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {
                if (onItemLongClickListener != null) {
                    onItemLongClickListener.onItemLongClick(v, position, getItem(position));
                    return true;
                }
                return false;
            }
        });
        setDate(holder, position);
    }

    //继承类的时候只需要重写这个方法,做以前在onBindViewHolder方法里的事情就可以了
    protected abstract void setDate(BaseViewHolder holder, int position);

    //做onCreateViewHolder的事情
    protected abstract BaseViewHolder getHolder(ViewGroup parent, int viewType);

    // 点击事件接口
    public interface OnItemClickListener<T> {
        void onItemClick(View view, int position, T model);
    }

    // 长按事件接口
    public interface OnItemLongClickListener<T> {
        void onItemLongClick(View view, int position, T model);
    }

    public void setOnItemClickListener(OnItemClickListener<T> onItemClickListener) {
        this.onItemClickListener = onItemClickListener;
    }

    public void setOnItemLongClickListener(OnItemLongClickListener<T> onItemLongClickListener) {
        this.onItemLongClickListener = onItemLongClickListener;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值