文档章节

Android ListView复杂列表优化实践

程序袁_绪龙
 程序袁_绪龙
发布于 2015/02/07 22:38
字数 1326
阅读 5943
收藏 39
点赞 0
评论 1

原文:Android ListView复杂列表优化实践



很多社交App都不免会涉及到复杂的列表元素实现,一个列表上面可能大量的图片,不定长的评论列表,给手机端的程序员带来了不少的挑战。本文就是在实现复杂的列表滑动的情况下,利用已知的优化方法指导下的一次优化实践,旨在提升ListView的滑动流畅度,为用户带来良好的体验。

1:设计稿:

 

这是列表中可能出现的ItemView,有两种,但是又有许多相同的地方,比如一样有点赞的图片,评论等...其中,评论和点赞的数量是可变的

2:使用一般布局带来的问题?

头像表格:如果使用自带的布局LinearLayout和ImageView来完成,会导致布局比较深,而且大量的addView操作会导致列表滑动的时候卡顿。

评论列表:和头像表格一样,由于Item的数量是会变化的,会带上和头像表格同样的问题。

大量图片加载: 不难看出图片的数量是可观的,由于每次请求回来的内容可能有很多条,如果数据一回来就请求里面带的全部图片链接,即使使用了线程池,也会占用cpu比较长的一段时间,因此也会带来界面的不流畅问题。

3:指导优化思路:

    (1): ViewHolder模式, 重用View和减少Child View查找时间,相信大家对这个都不陌生。

    (2): 尽可能减少布局层次

    (3): 只刷新变化的部分View

    (4): 避免调用addView这样的方法

    (5): 只加载当前视图需要的图片,并且在滑动列表的时候停止后台的加载线程,为UI线程空出cpu资源,在停止的时候再请求。

    (6): 首次加载图片就处理(圆角/缩放等)并缓存在本地

4:实践过程:

4.1:布局和View部分:

把【头像表格】和【评论列表】作为一个整体的自定义View来实现,右边的卡片结构基本一个RelativeLayout就可以实现了,这样整个Item就基本可以控制在3~4个层次深度上面。

【头像表格】实现注意点:

1):一开始应该先用默认头像填充,之后再图片返回的时候不要粗鲁地使用invalidate(),而是使用invalidate(Rect rect),进行局部刷新,响应点击事件更换背景时也应如此。

2):由于onMesure和onDraw的的过程是比较频繁和代价较高的,因此要尽可能复用对象,如(Paint, Rect...)

【评论列表】实现要点:

  1):除了上面提到的,这里有个难点就是字符串的绘制,什么时候该换行?这里涉及到非常复杂的文字处理,尤其是不同国家的不同文字系统,幸好,这些在Android API里面都有了相关实现,笔者是在TextView中找到的,也就是android.text.Layout 的几个实现类,笔者在这里只是使用了DynamicLayout来实现。通过这个类你可以获得字符串的高度信息(onMeasure),行数等...而且它已经实现了draw的过程,只需调整好画布的位置(canvas.translate),直接调用就可以了,非常方便。

【额外元素】

1):回到设计图上,我们看到还有可能出现的股票信息,对于这种额外元素,<ViewStub>最适合不过了...

【ListView】的数据变化:

  1):对于整个Item的增加或者删除动作,可以调用notifyDataChanged()。

2):对于Item内部的数据变化,不要粗鲁地使用notifyDataChanged(), 而是改变产生变化的View。

4.2:图片处理部分:

笔者一开始的想法是想做到:

1): 线程池,并且可以暂停所有下载线程和恢复下载

2): 双重缓存,本地永久缓存和内存级缓存

3): 滑动时候暂停所有下载,出让cpu资源给UI线程。

在实现的过程中,在多线程这里经常做的不好,经常出问题,非常幸运在github上找到了一个开源项目可以完美地解决上面的所有问题。现在我们公司的Android项目所有的图片加载已经自豪地使用上了... 附上地址:Android-Universal-Image-Loader

5:调整之后的效果:

由于笔者没有保留之前的界面卡顿时候的代码,因此只能演示最后的实现效果了,不能进行前后的比较。手机是小米4,图表是Developer选项中的Profile GPU rendering中,打开后前后不断滑动的结果。这里可以看到大部分情况都能在绿线下,说明整体的体验还是非常流畅的。

喜欢炒股的朋友也可以进一步去下载我们的应用:微财 , 即将在3.0版本可以体验到。


本文转载自:http://my.oschina.net/daxia/blog/376395

共有 人打赏支持
程序袁_绪龙
粉丝 97
博文 242
码字总数 66750
作品 0
普陀
程序员
加载中

评论(1)

qingzheng
qingzheng
测试安卓端程序
Android ListView复杂列表优化实践

原文:Android ListView复杂列表优化实践 很多社交App都不免会涉及到复杂的列表元素实现,一个列表上面可能大量的图片,不定长的评论列表,给手机端的程序员带来了不少的挑战。本文就是在实现...

叶大侠
2015/02/07
0
18
Android ListView优化实践

在看了一些vogella的文章之后,发现关于android listview性能优化这一段很有意思,于是实践了一下,经过优化,性能确实提升不少! 先看看优化前和优化后的比较: 优化前的log截图: 优化后的...

Jerikc
2013/03/23
0
0
android中的selector背景选择器

关于listview和button都要改变android原来控件的背景,在网上查找了一些资料不是很全,所以现在总结一下android的selector的用法。 首先android的selector是在drawable/xxx.xml中配置的。 先...

泡泡爸爸
2013/03/17
0
0
Android组件及UI框架大全

Android 是目前最流行的移动操作系统(还需要加之一吗?)。 随着新版本的不断发布, Android的功能也日益强大, 涌现了很多流行的应用程序, 也催生了一大批的优秀的组件。 本文试图将目前流行...

千山万水
2015/07/13
0
4
Android组件及UI框架大全

Android 是目前最流行的移动操作系统(还需要加之一吗?)。 随着新版本的不断发布, Android的功能也日益强大, 涌现了很多流行的应用程序, 也催生了一大批的优秀的组件。 本文试图将目前流行...

千山万水
2015/07/13
0
0
Android 的几种布局方式及实践

我们对Android应用程序运行原理及布局文件可谓有了比较深刻的认识和理解,并且用“Hello World!”程序来实践证明了。在继续深入Android开发之旅之前,有必要解决前两篇中没有介绍的遗留问题...

sumpower
2014/02/25
0
0
android listview 拖动 背景变黑

一般这种情况是在android 4.0一下版本会出现,在4.0内系统已经优化listview 但是还是建议把这些属性加上。触摸拖动list列表时,背景一片黑色。(增加相关属性) listView.setCacheColorHint(Co...

tfc
2014/03/17
0
0
listview与adapter用法

一个ListView通常有两个职责: (1)将数据填充到布局。 (2)处理用户的选择点击等操作。 第一点很好理解,ListView就是实现这个功能的。第二点也不难做到,在后面的学习中读者会发现,这非...

ARESXIONG
2015/11/03
0
0
Android系统源码分析团体项目BeesAndroid正式上线啦

嗨,BeesAndroid开源技术小组正式成立啦,Bees,即蜜蜂,取义分享、合作与奉献的意思,这也是BeesAndroid小组的宗旨,我们第一个团体项目BeesAndroid也于2018年3月6日同步上线,该项目的前 ...

郭孝星
03/08
0
0
Android listview与adapter用法

一个ListView通常有两个职责。 (1)将数据填充到布局。 (2)处理用户的选择点击等操作。 第一点很好理解,ListView就是实现这个功能的。第二点也不难做到,在后面的学习中读者会发现,这非...

OScoder2
2014/03/04
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

崛起于Springboot2.X之集成MongoDb使用mongoTemplate CRUD(27)

1、pom依赖 <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.7</version></dependency><dependency> <groupId>log4j</......

木九天
10分钟前
0
0
切分log日志

新建logback.xml放到resource里面 <?xml version="1.0" encoding="utf-8"?><configuration> <appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender"> <......

talen
16分钟前
0
0
spring @Resource 和 @Autowired 的使用区别

这两个 注解 @Resource 和 @Autowired , 常识都知道 @Resource 是 JAVAEE 自带的,@Autowired 是 spring 的自定义注解。 一般情况下, 使用 bean的时候, 这两个注解 随便使用一个即可。 但...

之渊
21分钟前
0
0
springboot集成elasticsearch客户端问题记录

1背景说明 服务端ES版本为5.5.2,springboot版本为1.5.6。 工程中添加如下依赖 2问题记录 2.1 NetworkPlugin类找不到 报错java.lang.ClassNotFoundException: org.elasticsearch.plugins.Net...

zjg23
23分钟前
1
0
快速构建ceph可视化监控系统

前言 ceph的可视化方案很多,本篇介绍的是比较简单的一种方式,并且对包都进行了二次封装,所以能够在极短的时间内构建出一个可视化的监控系统 本系统组件如下: ceph-jewel版本 ceph_expor...

万建宁
23分钟前
0
0
Java构造器使用注意

public class 父类A {int age = 10;protected void say() {System.out.println("父类A");}public 父类A() {override();}public void override() {Syst...

咸鱼AI
23分钟前
0
0
TensorFlow 线性分类

构造直线 z = 2 * x - 3 * y + 4 x0*w0+x1*w1+b=0 x1=-x0* w0/w1-b/w1 斜率 k= -w0/w1 截距 -b/w1 随机生成数据,加入一定的偏差,用直线将二维平面分为两部分 使用线性模型拟合参数 损失函数...

阿豪boy
26分钟前
0
0
翻译冒泡排序测试

翻译一个冒泡排序: var a = [1,3,2,4,6,5];var f = 0;var n = a.length ;for( var i =1; i<= n; i++) { for( var j = n-1 ; j >= i; j --) { if(a[j] < a[j+1]) { ......

钟元OSS
28分钟前
0
0
maven父、子级版本号同时修改

命令: mvn versions:set -DnewVersion=0.0.2-SNAPSHOT

沉默的懒猫
29分钟前
0
0
Spring boot中的异常处理之注解响应

Controller层 return patientRepository.findById(id) .orElseThrow(() -> new NotFoundException(String.format("Patient %d not found", id))); Exception类 @ResponseS......

亚林瓜子
30分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部