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

自己封装个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;
    }
}
在Android Studio中,要实现类似微博的界面,通常会结合ListView或RecyclerView(更推荐RecyclerView,因为它在性能上优于ListView,特别是在处理大量数据)以及相应的Adapter(如BaseAdapterRecyclerView.Adapter)。这里是一个简单的步骤概述: 1. **设置布局**: - 使用`LinearLayout`或者`ConstraintLayout`作为根布局,它将包含GridView用于显示四宫格图片和三个按钮(转发、评论、喜欢)。 ```xml <LinearLayout> <GridView ...> <!-- GridView for grid of images --> <FrameLayout> <Button (转发)> <Button (评论)> <Button (喜爱)> </FrameLayout> </LinearLayout> ``` 2. **创建Adapter**: - 对于ListView,你可以创建一个`BaseAdapter`的子类,继承自`ArrayAdapter`或`BaseAdapter`,并实现`getView()`方法来定制每个item的显示。 - 对于RecyclerView,使用`RecyclerView.Adapter`,通常你会创建一个`ViewHolder`类来复用和管理视图,并在`onCreateViewHolder()`和` onBindViewHolder()`方法中填充数据。 3. **添加GridLayoutManager**: - 如果使用GridView,需要创建一个`GridLayoutManager`来设置4宫格布局。 - 如果使用RecyclerView,同样创建一个`GridLayoutManager`,配置其行数和列数为4。 4. **处理按钮点击事件**: - 给按钮添加OnClickListener,当用户点击转发、评论或喜欢按钮,可以在对应的点击监听器中处理业务逻辑(如发送请求、更新UI等)。 5. **加载数据**: - 从API或其他数据源获取微博信息(包括图片和文本),并将数据封装到一个适配的数据结构(如List<YourDataModel>)中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值