首先放出一些相关类:
1、储存数据的类
data:image/s3,"s3://crabby-images/d7092/d7092a10c7fd4c7fe48d01439cb3cbac1aa4fceb" alt=""
、
2、GriView(和listView用法相似)的item布局
data:image/s3,"s3://crabby-images/358ed/358ed614c2159a4db965aba8139f50da621b2aac" alt=""
3、自定义的适配器
data:image/s3,"s3://crabby-images/84121/84121045e78434c3433ec137e95e843259467d0b" alt=""
这里就涉及到了优化问题,原生的ArrayAdapter在用户滑动的时候会不断的调用getView方法来加载View,不管是不是以前加载过的都会重复加载。
解决这个问题的方法关键在于getVIew方法的第二个参数,这个参数可以保存每一个位置加载的view,那么我们只要判断这个参数是否为空就可以知道这个item有没有被加载,已经加载的可以重复利用。
当然,这里还可以进一步优化一下,不用每一次加载view 的时候都绑定一下控件,我们把第一次加载view 的时候绑定好了的控件对象放入ViewHolder来储存一下。通过view的setTag()方法将ViewHolder对象和View绑定。
如果找到已经加载过的View那就getTag读出来即可。
data:image/s3,"s3://crabby-images/b922e/b922e7547099ea0710db8d122e6e6b5ced8bfcc2" alt=""
5、效果
data:image/s3,"s3://crabby-images/a2584/a25846f08b09f28338cf42a1bb061122d09ff0ca" alt=""
关于ArrayAdapter的使用可以看上一篇文章
网友评论