专栏首页Android开发小工RecyclerView的通用快速适配封装

RecyclerView的通用快速适配封装

这次的主题是封装RecyclerView的单选多选,现在大家应该都是用的RecyclerView开发列表数据吧。网上也有很多RecyclerView的封装库,各种眼花缭乱的功能,这里分享一个我自己项目里用的简易版RecyclerView 的轻便版封装吧。

其实这篇博客是我后面一篇博客的准备~一句话实现RecyclerView的单选多选的选项列表

先看图,这些都是RrcyclerView做的各种样式的列表数据视图~

多选样式图:

multichoice.jpg

1、封装通用ViewHolder
        public static class VH extends RecyclerView.ViewHolder {
        
        private SparseArray<View> mViews;
        private View mConvertView;

        private VH(View v) {
            super(v);
            mConvertView = v;
            mViews = new SparseArray<>();
        }

        public static VH get(ViewGroup parent, int layoutId) {
            View convertView = LayoutInflater.from(parent.getContext()).inflate(layoutId, parent, false);
            return new VH(convertView);
        }

        public <T extends View> T getView(int id) {
            View v = mViews.get(id);
            if (v == null) {
                v = mConvertView.findViewById(id);
                mViews.put(id, v);
            }
            return (T) v;
        }

        public void setText(int id, String value) {
            TextView view = getView(id);
            view.setText(value);
        }
}

原理就是通过SparseArray<View>存储item view的控件(不知道SpareseArray的请自行google这个数据结构的Api),getView(int id)的功能就是通过id获得对应的View:因为findViewById比较耗费性能,首先在mViews中查询是否存在,如果没有,那么findViewById()并放入mViews中,避免下次再执行findViewById()。

2、封装RecyclerView的通用快速开发adapter
public abstract class AbsRecycleAdapter<T> extends RecyclerView.Adapter<AbsRecycleAdapter.VH> {

    private OnItemClickListener mItemClickListener;

    private List<T> mData;

    @Override
    public VH onCreateViewHolder(ViewGroup parent, int viewType) {
        final VH viewHolder = VH.get(parent, getLayoutId(viewType));

        viewHolder.itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                int position = viewHolder.getAdapterPosition();
                if (mItemClickListener != null) {
                    mItemClickListener.onItemClick(position, v);
                }
            }
        });
        return viewHolder;
    }

    @Override
    public void onBindViewHolder(VH holder, int position) {
        convert(holder, mData.get(position), position);
    }

    public abstract int getLayoutId(int viewType);

    public abstract void convert(VH holder, T data, int position);

    public void setOnItemClickListener(OnItemClickListener listener) {
        this.mItemClickListener = listener;
    }

    public void setData(List<T> beans) {
        if (null == mData) {
            mData = new ArrayList<>();
        }
        mData.clear();
        if (ValidateUtil.isValidate(beans)) {
            mData.addAll(beans);
        }
    }

    public void addData(List<T> beans) {
        if (null == mData) {
            setData(beans);
        } else {
            mData.addAll(beans);
        }
    }

    public void addData(T t) {
        if (mData == null) {
            mData = new ArrayList<>();
        }
        if (!mData.contains(t)) {
            mData.add(t);
        }
    }

    public void remove(T t) {
        if (null != mData) {
            mData.remove(t);
        }
    }

    public List<T> getData() {
        return mData;
    }

    public void clear() {
        if (mData != null) {
            mData.clear();
        }
    }

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

    public T getItem(int position) {
        if (mData != null) {
            return mData.get(position);
        }
        return null;
    }

    public interface OnItemClickListener {
        void onItemClick(int position, View v);
    }

    public static class VH extends RecyclerView.ViewHolder {
        private SparseArray<View> mViews;
        private View mConvertView;

        private VH(View v) {
            super(v);
            mConvertView = v;
            mViews = new SparseArray<>();
        }

        public static VH get(ViewGroup parent, int layoutId) {
            View convertView = LayoutInflater.from(parent.getContext()).inflate(layoutId, parent, false);
            return new VH(convertView);
        }

        public <T extends View> T getView(int id) {
            View v = mViews.get(id);
            if (v == null) {
                v = mConvertView.findViewById(id);
                mViews.put(id, v);
            }
            return (T) v;
        }

        public void setText(int id, String value) {
            TextView view = getView(id);
            view.setText(value);
        }

        public void setTextColor(int id, @ColorInt int color) {
            TextView view = getView(id);
            view.setTextColor(color);
        }

        public void setTextBackgroundResource(int id, @DrawableRes int resid) {
            TextView view = getView(id);
            view.setBackgroundResource(resid);
        }

        public void setBackgroundResource(int id, @DrawableRes int resId) {
            View view = getView(id);
            view.setBackgroundResource(resId);
        }

        public void setViewShow(int id, boolean isShow) {
            View view = getView(id);
            view.setVisibility(isShow ? View.VISIBLE : View.GONE);
        }

        public void setImageUrl(int id, String imageUrl) {
            ImageView imageView = getView(id);
            Glide.with(itemView.getContext())
                    .load(imageUrl)
                    .placeholder(R.mipmap.banner)
                    .error(R.mipmap.banner)
                    .into(imageView);
        }

        public void setImageResid(int id, int resourceId) {
            ImageView imageView = getView(id);
            imageView.setImageResource(resourceId);
        }

        public void setImageCircleAvatarUrl(int id, String imageUrl) {
            ImageView imageView = getView(id);
            Glide.with(itemView.getContext())
                    .load(imageUrl)
                    .placeholder(R.mipmap.avatar_default)
                    .error(R.mipmap.avatar_default)
                    .bitmapTransform(new GlideCircleTransform(itemView.getContext()))
                    .into(imageView);
        }

    }


}

全部代码

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 数据结构基础-栈和队列

    栈是一个有序线性表,只能在表的一端(成为栈顶,top)执行插入和删除操作。最后插入的元素将第一个被删除。所以栈也称为后进先出(Last In First Out...

    1025645
  • 完全自定义样式的一句话实现RecyclerView的单选多选

    今天的主题是封装RecyclerView的单选多选,现在大家应该都是用的RecyclerView开发列表数据吧。

    1025645
  • View的位置参数及其Scroller类的理解

    x和y是View左上角的坐标,translationX和translationY是View左上角相对于容器的偏移量。这几个参数都是相对于父容器的坐标。

    1025645
  • Mybatis 3.5新特性——Optional支持

    Mybatis 3.5 发布有段时间了,终于支持了 Optional ,这么实用的特性,竟然还没人安利……于是本文出现了。

    wuweixiang
  • mybatis学习之高级映射

    一对一映射查询 1、数据库执行脚本: /* SQLyog Ultimate v12.09 (64 bit) MySQL - 5.7.11-log : Datab...

    用户1141560
  • 初探Google Guava

    第一次接触我是在16年春github上,当时在找单机查缓存方法,google guava当初取名是因为JAVA的类库不好用,所以谷歌工程师自己开发一套,想着go...

    爱撸猫的杰
  • 教程 | 手把手教你在本地构建Nervos AppChain全家桶

    本文依据博文教程以及Nervos AppChain官方文档,带你搭建一个Dapp。

    数据派THU
  • WCF 入门(19)

    上一集介绍了使用SOAP fault而不是默认的.net Exception来避免由于异常使当前的channel进入faulted状态。这集介绍如何使用强类型的...

    _淡定_
  • CentOS8 安装MySQL8.0

    运行mysql_secure_installation脚本,该脚本执行一些与安全性相关的操作并设置MySQL根密码:

    双面人
  • 面试总被问分布式ID怎么办? 滴滴(Tinyid)甩给他

    接着《一口气说出 9种 分布式ID生成方式,面试官有点懵了》来继续详细的介绍分布式ID生成器,大家比较感兴趣的美团(Leaf)、滴滴(Tinyid)、百度(ui...

    程序员内点事

扫码关注云+社区

领取腾讯云代金券