listView懒加载解决快速拖动卡屏问题

本文详细介绍了如何在ListView中使用懒加载技术解决拖动卡顿问题。通过判断ListView的状态,仅在静止时加载实际图片,避免了大量图片加载导致的性能瓶颈。具体实现包括在Activity创建时获取所有缩略图,在Adapter的getview方法中判断滚动状态,并在滚动状态变为静止时更新图片内容。
摘要由CSDN通过智能技术生成
快速拖动  上下拖动很卡的原因 listView中有大量的图片,每张图片在生存时候会花200毫秒,
 
解决:利用listView的懒加载   :当拖动时候不去加载ListView中的条目,当用户停止的时候才
真正去加载这个条目
判断ListView的状态,如果ListView是处于滚动状态,返回一个假的View对象,gieView()执行很快
只有当listView处于静止状态的时候,才去真正去更新里面显示的内容
5.listview的懒加载
   判断listview的状态,如果listview是处于滚动状态.返回一个假的view对象.
   只有当listview处于静止状态的时候 ,才去真正的更新里面所显示的内容.
 
    1.在activity创建的时候,获取到所有的缩略图...
 
   2.在adapter的getview的方法里面判断 当前listview是否处于滚动状态.
   滚动状态可以通过 listview的setonscroollistener的方式 处理
  onScrollStateChanged(AbsListView view, int scrollState) {
        switch (scrollState) {
        case OnScrollListener.SCROLL_STATE_IDLE:
            滚动= false;
            break;
        case OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:
            滚动= true;     
            break;
        case OnScrollListener.SCROLL_STATE_FLING:
            滚动= true;
            break;
 
如果是滚动状态 就只返回,缩略图.
并且把真实图片的id存储起来.并且可以储存当前imageview的引用.
 
3.当滚动状态变成静止的时候 再去真正的加载每个真实的图片.
在case OnScrollListener.SCROLL_STATE_IDLE:
//获取第一个listview可见的条目的位置
  int first = listview.getFirstVisiblePosition();
// 获取listview里面显示的条目的个数.
  int count = view.getChildCount();
通过for循环 更新所有的图片
for (int i=0; i<count; i++) {
         拿到图片的id,和imageview,更新里面的内容.    
 
            }
 
这种方法,可以解决掉拖动卡顿的现象.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值