RecyclerView万能适配器

1.先写一个BaseAdapter

public abstract class BaseRecyclerViewAdapter<T> extends RecyclerView.Adapter<BaseRecyclerViewAdapter.ViewHolder> {
    protected List<T> tList;
    protected Context mContext;
    protected LayoutInflater mLayoutInflater;
    protected int layId;

    private OnItemClickListener mOnItemClickListener;

    public BaseRecyclerViewAdapter(List<T> tList, Context mContext, int layId) {
        this.tList = tList;
        this.mContext = mContext;
        this.layId=layId;
        mLayoutInflater=LayoutInflater.from(mContext);
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = mLayoutInflater.inflate(layId, parent, false);
        ViewHolder viewHolder = new ViewHolder(view);
        return viewHolder;
    }
    @Override
    public void onBindViewHolder(final BaseRecyclerViewAdapter.ViewHolder holder, final int position) {
        convert(holder,tList.get(position));
        holder.itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                mOnItemClickListener.onItemClick(position,holder);
            }
        });

    }
    public void setOnItemClickListener(OnItemClickListener onItemClickListener){
        this.mOnItemClickListener=onItemClickListener;

    }

    @Override
    public int getItemCount() {
        return tList.size();
    }

    public abstract  void convert(ViewHolder holder,T itemData);


    public class ViewHolder extends RecyclerView.ViewHolder {

        public ViewHolder(View itemView) {
            super(itemView);

        }

    }

     /**
     * 点击事件接口
     */
    public interface OnItemClickListener{
        void onItemClick(int position,BaseRecyclerViewAdapter.ViewHolder viewHolder);
    }



}

2.写一个adapter 继承上面写的Base

public class RecyclerAdapter extends BaseRecyclerViewAdapter<String> {
    public RecyclerAdapter(List<String> lists, Context mContext, int layId, RecyclerView recyclerView) {
        super(lists, mContext, layId);
        recyclerView.setLayoutManager(new LinearLayoutManager(mContext));
    }
    @Override
    public void convert(ViewHolder holder, String itemData) {
        ((TextView)holder.itemView.findViewById(R.id.text)).setText(itemData);
    }
}

3.然后再函数中传入布局使用使用

recler = findViewById(R.id.recler);
        List<String> Str = new ArrayList<String>();
        for (int i = 0; i <10 ; i++) {
            Str.add("10");
        }
        RecyclerAdapter recyclerAdapter = new RecyclerAdapter(Str, this, R.layout.item_recycler, recler);
        recler.setAdapter(recyclerAdapter);

        recyclerAdapter.setOnItemClickListener(new BaseRecyclerViewAdapter.OnItemClickListener() {
            @Override
            public void onItemClick(int position, BaseRecyclerViewAdapter.ViewHolder viewHolder) {
//                viewHolder.setText(R.id.text,"9");
            }
        });

 

4.下面我们可以对ViewHolder进行一些优化

public class ViewHolder extends RecyclerView.ViewHolder {

        private SparseArray<View> mViewArray;

        public ViewHolder(View itemView) {
            super(itemView);
            mViewArray=new SparseArray<>();
        }

        /**
         * 通过id得到view
         * @param viewId
         * @param <V>
         * @return
         */
        public <V extends View>V getViewAtId(int viewId){
            View view = mViewArray.get(viewId);
            if(view==null){
                view=itemView.findViewById(viewId);
                mViewArray.put(viewId,view);
            }
            return (V)view;
        }

        /**
         * 设置文字
         * @param viewId
         * @param text
         * @return
         */
        public ViewHolder setText(int viewId,CharSequence text){
           TextView textView= getViewAtId(viewId);
           textView.setText(text);
           return  this;
        }

        /**
         * 通过网址设置图片
         * @param viewId
         * @param imgUrl
         * @return
         */
        public ViewHolder setImageFromUrl(int viewId,String imgUrl){
           ImageView imageView= getViewAtId(viewId);
            Glide.with(imageView.getContext()).load(imgUrl).into(imageView);
            return this;
        }

        /**
         * 通过资源来设置图片资源
         * @param viewId
         * @param resId
         * @return
         */
        public ViewHolder setImageFromRes(int viewId,int resId){
            ImageView imageView = getViewAtId(viewId);
            imageView.setImageResource(resId);
            return this;
        }

        /**
         * 设置控件透明度
         * @param viewId
         * @param visibility
         * @return
         */
        public ViewHolder setViewVisibility(int viewId,int visibility){
            View view = getViewAtId(viewId);
            view.setVisibility(visibility);
            return this;
        }


    }

4.1  RecyclerAdapter就可以这么写了

 @Override
    public void convert(final ViewHolder holder, final String itemData) {
        holder.setText(R.id.text,itemData);
    }

 

 

5.多布局接口的实现   在BaseRecyclerViewAdapter里面 添加

private MultiTypeSupport<T> multiTypeSupport;
    /**
     * 多布局接口
     * @param <T>
     */
    public interface  MultiTypeSupport<T>{
        int getLayoutId(T item);
    }
    public void setMultiTypeSupport(MultiTypeSupport<T> multiTypeSupport){
        this.multiTypeSupport=multiTypeSupport;
    }


    @Override
    public int getItemViewType(int position) {
        if (multiTypeSupport!=null){
            return multiTypeSupport.getLayoutId(tList.get(position));
        }
        return super.getItemViewType(position);
    }

 

6.在主函数里面进行数据判断来切换布局

recyclerAdapter.setMultiTypeSupport(new BaseRecyclerViewAdapter.MultiTypeSupport<String>() {
            @Override
            public int getLayoutId(String item) {
                if(item.equals("horizontalScrollCard")){
                    return R.layout.item_recyclerview_clidfragment;
                }else if(item.equals("header5")){
                    return R.layout.item_recyclerview_nofragment;
                }


                return 0;
            }
        });

最后一个问题,我们应该怎么在convert方法中实现对不同的布局进行不同的数据加载呢?毕竟我们这个方法的传入参数可没有ViewType。
我们可以在直接通过item数据来判断就可以了。

这个适配器不能用于ViewPager  不然他不会测量高度

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RecyclerView原生适配器RecyclerView的一个重要组件,用于将数据与RecyclerView中的视图进行绑定。RecyclerView原生适配器提供了一些默认的视图绑定方法,如创建视图、绑定数据、设置视图大小等。同时,它也允许我们自定义视图绑定方法,以满足不同的需求。 RecyclerView原生适配器的基本用法如下: 1. 创建一个继承自RecyclerView.Adapter的适配器类,实现必要的方法,如onCreateViewHolder、onBindViewHolder和getItemCount等。 2. 在onCreateViewHolder方法中创建视图,并返回一个ViewHolder对象。 3. 在onBindViewHolder方法中将数据与视图进行绑定。 4. 在getItemCount方法中返回数据项的数量。 5. 将适配器对象设置到RecyclerView中即可显示数据。 示例代码如下: ``` public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mData; public MyAdapter(List<String> data) { mData = data; } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(ViewHolder holder, int position) { holder.mTextView.setText(mData.get(position)); } @Override public int getItemCount() { return mData.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { public TextView mTextView; public ViewHolder(View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.text_view); } } } ``` 在上面的代码中,我们定义了一个MyAdapter类,继承自RecyclerView.Adapter,并在其中实现了必要的方法。在onCreateViewHolder方法中,我们使用LayoutInflater来创建视图,并将其封装在ViewHolder对象中返回。在onBindViewHolder方法中,我们将数据与视图进行绑定。在getItemCount方法中,我们返回数据项的数量。最后,我们将适配器对象设置到RecyclerView中即可显示数据。 需要注意的是,RecyclerView原生适配器只提供了基本的视图绑定方法,如果需要实现更复杂的视图绑定,我们可以使用第三方的适配器库,如BaseRecyclerViewAdapterHelper等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值