解决Android快速滑动时图片一闪一闪问题

 更新时间:2015年07月31日 08:57:40   投稿:hebedich  
这篇文章主要给大家介绍了个人在解决Android快速滑动时图片一闪一闪问题的一些思路和方法,非常实用,有需要的小伙伴可以参考下。

快速滑动图片一闪一闪的问题,图片加载等处理在这里不介绍,主要就是介绍下在Adapter中维护一个LinkedHashMap解决上述问题

package com.longraise.seller.adapter;
 
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.drawable.BitmapDrawable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
 
import com.longraise.seller.R;
import com.longraise.seller.view.VoiceButton;
 
import java.lang.ref.SoftReference;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
 
import cc.sdkutil.control.image.CCImageLoader;
import cc.sdkutil.control.image.CCImageLoaderCallback;
import cc.sdkutil.control.inject.CCInjectUtil;
import cc.sdkutil.model.inject.CCInjectRes;
 
/**
 * Created by wangcong on 15-1-8.
 */
public class OrderFinishAdapter extends BaseAdapter {
 
  //convertview id
  private final static int BASE_ID = 0x0fff00;
 
  private Context mContext;
  private List<Map<String, Object>> mAllList;
 
  //图片加载相关
  CCImageLoader mImageLoader;
  //用于缓存图片,减小快速滑动时图片显示落帧现象
  final LinkedHashMap<String, SoftReference<Bitmap>> linkedHashMap;
  final int MAX_SIZE = 16;
 
  public OrderFinishAdapter(Context context, List<Map<String, Object>> list) {
    this.mContext = context;
    this.mAllList = list;
    linkedHashMap = new LinkedHashMap<String, SoftReference<Bitmap>>(16, 0.75f, true) {
 
      private static final long serialVersionUID = 1L;
 
      @Override
      protected boolean removeEldestEntry(Entry<String, SoftReference<Bitmap>> eldest) {
        boolean flag = size() > MAX_SIZE;
        if (flag) {
          SoftReference<Bitmap> softReference = eldest.getValue();
          Bitmap bitmap = softReference.get();
          if (bitmap != null) bitmap.recycle();
          remove(eldest.getKey());
        }
        return flag;
      }
    };
  }
 
  public int getCount() {
    return mAllList.size();
  }
 
  public Object getItem(int position) {
    return mAllList.get(position);
  }
 
  public long getItemId(int position) {
    return position;
  }
 
  @SuppressWarnings("deprecation")
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder = null;
    if (convertView == null) {
      convertView = LayoutInflater.from(mContext).inflate(R.layout.adapter_finish_item, parent, false);
      holder = new ViewHolder();
      CCInjectUtil.inject(holder, convertView);
      convertView.setTag(holder);
    } else {
      holder = (ViewHolder) convertView.getTag();
    }
    convertView.setId(BASE_ID + position);
    final Map<String, Object> map = mAllList.get(position);
    //处理图片
    SoftReference<Bitmap> softReference = linkedHashMap.get(map.get("orderImgUrl"));
    Bitmap bitmap = softReference == null ? null : softReference.get();
    if (bitmap == null) {
      holder.image.setBackgroundResource(R.drawable.default_image_error);
      if (mImageLoader == null)
        mImageLoader = new CCImageLoader.Builder().needCacheInDisk().outSize(120, 120)
            .callback(new CCImageLoaderCallback() {
              @Override
              public void onSuccess(Bitmap bitmap, Object... objs) {
                super.onSuccess(bitmap, objs);
                if (bitmap != null) { //图片加载成功后处理
                  ImageView imageView = (ImageView) objs[0];
                  imageView.setBackgroundDrawable(new BitmapDrawable(mContext.getResources(), bitmap));
                  SoftReference<Bitmap> soft = new SoftReference<Bitmap>(bitmap);
                  linkedHashMap.put(objs[1] + "", soft);
                  bitmap = null;
                }
              }
            }).build();
      mImageLoader.loadNetImage(map.get("orderImgUrl") + "", holder.image, map.get("orderImgUrl"));
    } else {
      holder.image.setBackgroundDrawable(new BitmapDrawable(mContext.getResources(), bitmap));
    }
 
    
    return convertView;
  }
 
  static class ViewHolder {
 
    @CCInjectRes(R.id.order_item_image)
    ImageView image;
  }
}

以上所述就是本文的全部内容了,希望大家能够喜欢。

相关文章

  • Android ProductFlavor的使用详解

    Android ProductFlavor的使用详解

    如果你的项目需要要区分国内版和国外版甚至还要根据用户是否是VIP会员加上收费和免费的版本,我们可以使用ProductFlavor对UI布局和icon图标进行版本区分,有此类需求的朋友,不妨了解下本文
    2021-06-06
  • Android ViewPager自定义轮播图并解决播放冲突

    Android ViewPager自定义轮播图并解决播放冲突

    这篇文章主要为大家详细介绍了Android ViewPager自定义轮播图并解决播放冲突,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Android View.Post 的原理及缺陷

    Android View.Post 的原理及缺陷

    这篇文章主要介绍了Android View.Post 的原理及缺陷,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下
    2021-03-03
  • Android仿视频加载旋转小球动画效果的实例代码

    Android仿视频加载旋转小球动画效果的实例代码

    这篇文章主要介绍了Android仿视频加载旋转小球动画效果的实例代码,文中给大家提到了PathMeasure的用法,介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • Flutter 仿微信支付界面

    Flutter 仿微信支付界面

    网传微信支付页面的第三方链接一个格子需要广告费1一个亿,微信支付页非常适合做功能导航,本篇使用 ListView和 GridView 模仿了微信支付的页面,同时介绍了如何装饰一个组件的背景和边缘样式。
    2021-05-05
  • Android7.0开发实现Launcher3去掉应用抽屉的方法详解

    Android7.0开发实现Launcher3去掉应用抽屉的方法详解

    这篇文章主要介绍了Android7.0开发实现Launcher3去掉应用抽屉的方法,结合实例形式分析了Android7.0 Launcher3调整界面布局的相关操作技巧与注意事项,需要的朋友可以参考下
    2017-11-11
  • android原生实现多线程断点续传功能

    android原生实现多线程断点续传功能

    这篇文章主要为大家详细介绍了android原生实现多线程断点续传功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • 在Android app中实现九(n)宫格图片连续滑动效果

    在Android app中实现九(n)宫格图片连续滑动效果

    这篇文章主要介绍了在Android app中实现九(n)宫格图片连续滑动效果的方法,作者举了凤凰新闻应用的例子,同理功能图标也可以利用这样的滑动效果,需要的朋友可以参考下
    2016-02-02
  • 基于Android实现3D翻页效果

    基于Android实现3D翻页效果

    这篇文章主要为大家详细介绍了基于Android实现3D翻页效果的具体代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • 使用Flutter定位包获取地理位置

    使用Flutter定位包获取地理位置

    本文详细讲解了使用Flutter定位包获取地理位置的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11

最新评论