欠伸展肢体,吟咏心自愉。这篇文章主要讲述android开发:列表listview的实现 | 下拉刷新相关的知识,希望能为你提供帮助。
APP里面的列表太常用了,系统提供的listview或grideview可以做到。另外,我希望这个列表能够下拉时触发刷新,于是考虑使用封装了这个功能的开源项目,这里介绍这个:
https://github.com/Yalantis/Phoenix
这是一个支持下拉刷新的控件,里面包括了ListView。
(1)引入下拉刷新库同样,先引入这个库,在app/build.gradle的dependencies中增加一行:
implementation ‘com.yalantis:phoenix:1.2.3‘(2)xml中设计下拉刷新控件然后在界面中使用这个控件,比如“知音”这个APP是在Fragment中使用,部分xml是这样的:
文章图片
对于它的使用,你也可以参考它在github上的说明。
(3)代码中使用下拉刷新控件在代码中,处理触发刷新的事件:
文章图片
至此,界面就出现了一个能够下拉刷新的控件。但是,数据(包括刷新出来的数据)最终要在ListView上显示出来,所以,下一步就是使用ListView。
(4)使用ListView来显示内容跟ios的tableview一样,ListView也是由一个个cell(item)组成的,需要设计这个cell怎么显示,于是,可以写一个xml,比如叫tianya_listcell.xml:
文章图片
文章图片
文章图片
这个xml是cell显示的样式,除了样式,还要有内容。ListView从适配器取内容,所以要写一个适配器类来提供内容(重写某个方法)。
先定义一个内容类,这里简单演示,只设置一个图片。定义的类是这样的:
文章图片
最终要使用这个内容类,生成一个list,再设置给listview的适配器。
然后,写listview的适配器,由它提供绘制内容:
文章图片
文章图片
最后,使用listview:
文章图片
总体的思路是,listview向adapter询问绘制多少个item(所以要给adapter设置好数据列表),再问adapter索要绘制的view(这个view从xml中生成,就是一个item),我们可以重写这个getView的方法,从而控制显示什么样的item(xml定义了布局,除了布局,还要设置具体的显示内容,就在这个函数里面设置)。
【android开发(列表listview的实现 | 下拉刷新)】演示的效果是这样的:
文章图片
推荐阅读
- create-react-app里添加less
- Android中适配器的notifyDataSetChanged()为何有时不刷新
- Vant Weapp小程序蹲坑之使用submit-bar组件
- visual studio 2017 中默认无法开发 Android 8.0 及以上系统的解决方案
- Office Web Apps 2013 修改Excel在线查看文件大小限制
- Android-引导用户指纹录入
- react使用 create-react-app 构建基于TypeScript的React前端架构----上
- Native APP ,Web APP,Hybrid APP三者对比
- .NET Core中使用AutoMapper