3-VI--☆ListView的封装
零、前言
[1].第一次自己ListView封装时,封装的比较差,用起来不是很好用,虽然比起原生好很多
[2].第二次接触ListView封装是在慕课网hyman的课程,深深折服
[3].基于此思想,自己封装了RecyclerView
一、使用
1.使用起来只要两步
public class Up3Activity extends AppCompatActivity { @BindView(R.id.lv) ListView mLv; private ArrayList<String> mNames; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ButterKnife.bind(this); mNames = DataUtils.getRandomName(200000, true); mLv.setAdapter(new MyLVAdapter<String>(this, mNames, R.layout.item_array_with_img) { @Override public void setData(MyLVHolder holder, String data, int position) { holder.setText(R.id.tv_content, data); } }); } }
二、封装过程:
1. MyLVHolder类
/** * 作者:张风捷特烈 * 时间:2018/4/6:11:30 * 邮箱:1981462002@qq.com * 说明:MyLVHolder */ public class MyLVHolder { /** * 条目内部控件的view集合 */ private SparseArray<View> mViews; /** * 位置 */ private int mPosition; /** * 条目视图 */ private View mItemView; private List<Integer> mPos; /** * @param ctx 上下文 * @param parent parent * @param layoutId 布局ID * @param position 位置 */ public MyLVHolder(Context ctx, ViewGroup parent, int layoutId, int position) { mPosition = position; mViews = new SparseArray<>(); //生成条目的View mItemView = LayoutInflater.from(ctx).inflate(layoutId, parent, false); //用MyLVHolder为条目View设置标签 mItemView.setTag(this); } /** * 获取 MyLVHolder 对象 * * @param ctx 上下文 * @param convertView convertView * @param parent parent * @param layoutId 布局ID * @param position 位置 * @return MyLVHolder 对象 */ public static MyLVHolder get(Context ctx, View convertView, ViewGroup parent, int layoutId, int position) { //convertView为空 if (convertView == null) { //创建MyLVHolder对象 return new MyLVHolder(ctx, parent, layoutId, position); } else { //复用MyLVHolder MyLVHolder holder = (MyLVHolder) convertView.getTag(); holder.mPosition = position;//更新position return holder; } } public List<Integer> handleCheckBox(int checkBoxId) { mPos = new ArrayList<>(); final CheckBox cb = this.getView(checkBoxId); cb.setChecked(false); if (mPos.contains(this.getPosition())) { cb.setChecked(true); } cb.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (cb.isChecked()) { mPos.add(getPosition()); } else { mPos.remove((Integer) getPosition()); } } }); return mPos;//返回选中的CheckBox位置集合 } public View getItemView() { return mItemView; } /** * 通过viewId获取控件 * * @param viewId 条目内部控件的id * @param <T> 数据泛型 * @return view */ public <T extends View> T getView(int viewId) { //通过viewId为键获取View值 View view = mViews.get(viewId); //如果view为空 if (view == null) { //条目findViewById获取View view = mItemView.findViewById(viewId); //以id为键,View为值存入mViews集合 mViews.put(viewId, view); } return (T) view; } public View getConvertView() { return mItemView; } public int getPosition() { return mPosition; } /** * 设置TextView文本方法 * * @param viewId 条目内部控件的id * @param text 文本 * @return MyLVHolder对象 */ public MyLVHolder setText(int viewId, String text) { TextView view = getView(viewId); view.setText(text); return this; } /** * 通过id设置图片 * @param viewId 条目内部控件的id * @param resId 资源id * @return MyLVHolder对象 */ public MyLVHolder setImageViewRes(int viewId, int resId) { ImageView view = getView(viewId); view.setImageResource(resId); return this; } /** * 通过id设置图片 * @param viewId 条目内部控件的id * @param bitmap 图片 * @return MyLVHolder对象 */ public MyLVHolder setImageViewBitmap(int viewId, Bitmap bitmap) { ImageView view = getView(viewId); view.setImageBitmap(bitmap); return this; } }
2.适配器类:MyLVAdapter
/** * 作者:张风捷特烈 * 时间:2018/4/6:13:51 * 邮箱:1981462002@qq.com * 说明:ListView适配器 */ public abstract class MyLVAdapter<T> extends BaseAdapter { /** * 数据 */ protected List<T> mDatas; /** * 布局ID */ protected int mLayoutId; /** * 上下文 */ protected Context mCtx; public MyLVAdapter(Context ctx, List<T> datas, int listId) { mCtx = ctx; mDatas = datas; mLayoutId = listId; } @Override public int getCount() { return mDatas.size(); } @Override public T getItem(int position) { return mDatas.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { //创建 MyLVHolder 对象 MyLVHolder holder = MyLVHolder.get(mCtx, convertView, parent, mLayoutId, position); setData(holder, getItem(position), position); return holder.getConvertView(); } /** * 设置数据抽象方法 * @param holder MyLVHolder * @param data 数据 * @param position 位置 */ public abstract void setData(MyLVHolder holder, T data, int position); }
附录、布局:
activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <ListView android:id="@+id/lv" android:layout_width="match_parent" android:layout_height="match_parent" android:fastScrollEnabled="true"> </ListView> </LinearLayout>
layout/item_array_with_img.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="10dp"> <ImageView android:id="@+id/iv_icon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@mipmap/ic_launcher"/> <TextView android:id="@+id/tv_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_margin="5dp" android:textSize="18sp" android:textColor="#000" android:layout_toRightOf="@+id/iv_icon" android:text=""/> </RelativeLayout>
后记、
1.声明:
[1]本文由张风捷特烈原创,转载请注明
[2]欢迎广大编程爱好者共同交流
[3]个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正
[4]你的喜欢与支持将是我最大的动力
2.连接传送门:
更多安卓技术欢迎访问:安卓技术栈
我的github地址:欢迎star
简书首发,腾讯云+社区同步更新
张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com
3.联系我
QQ:1981462002
邮箱:1981462002@qq.com
微信:zdl1994328
4.欢迎关注我的微信公众号,最新精彩文章,及时送达:

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Android 异步消息分发机制
Android的消息机制–主要是指 Handler 的运行机制 和 MessageQueue 、 looper 的工作过程。 MessageQueueMessageQueue 消息队列,用来存储消息,虽然称为消息队列,但是它的存储结构是采用 单链表的数据结构来存储消息队列的。 包含两个操作插入(enqueueMessage) 和 读取(next) enqueueMessage :往消息链表 中插入一条信息 next:从消息列表中读取一天消息,并将其从消息队列中移除,next方法是一个无限循环的方法,如果消息列表里没有消息,那么会一直阻塞在这里。 LooperLooper 消息循环,用来处理消息。 Looper 会不停的从 MessageQueue 中查看是否有新的消息,如果有新消息就会立即处理Looper.java private Looper(boolean quitAllowed) { mQueue = new MessageQueue(quitAllowed); mThread = Thread.currentThread(); } 在 Looper 的构造方法会创建一个Mess...
- 下一篇
小程序踩坑第二谈
小程序学习总结 首先贴上官方文档的链接地址 小程序开发文档 1. 触发 upper 和 lower 事件的条件。如何在 scroll-view 中触发该条件 首先 upper 事件和 lower 事件是在 scroll-view 中使用,可以用在上拉自动加载和下拉刷新;或者单独的下拉刷新也可以,即 onPullDownRefresh,不过需要在全局变量中开启才行。 *在滚动 scroll-view 时会阻止页面回弹,所以在 scroll-view 中滚动,是无法触发 onPullDownRefresh 注意 scroll-view 和 onPullDownRefresh 是不能够同时使用的,这个在开发文档中也有提示。 虽然都有文档但还是需要我们自己去踩坑才能更好的学习了解,下面是 demo upper-threshold 是表示距顶部/左边多远时(单位px),触发 scrolltoupper 事件; lower-threshold 是表示距底部/右边多远时(单位px),触发 scrolltolower 事件,定义好之后在 .js 文件中定义函数即可。 2 . 跳转带有底部菜单的时候...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS关闭SELinux安全模块
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7设置SWAP分区,小内存服务器的救世主