当前位置: 首页 > 编程笔记 >

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

易流觞
2023-03-14
本文向大家介绍解决Android快速滑动时图片一闪一闪问题,包括了解决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;
  }
}

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

 类似资料:
  • 本文向大家介绍Mysql闪退问题图文解决办法,包括了Mysql闪退问题图文解决办法的使用技巧和注意事项,需要的朋友参考一下 之前在使用MySQL 5.5 Command Line Client时, 无论输入什么密码,都出现闪退的情况,后来查找资料才发现原来是之前使用360时,将mysql服务给关了,现将解决办法总结如下: 1.桌面找到计算机-->右键选择管理; 2.在管理页面点击服务,展开服务项;

  • 我创建小应用程序来显示我的问题。您可以在https://github.com/anton111111/exampleglideblink中看到它。 当我调用RecyerView适配器上的notifyItemChanged时,我只需要更改文本(在我的示例中,它使用id r.id.progress EditText)和图像,而不需要更改。但它会眨眼。 我有能力不眨眼地更改文本吗?

  • 本文向大家介绍python解决OpenCV在读取显示图片的时候闪退的问题,包括了python解决OpenCV在读取显示图片的时候闪退的问题的使用技巧和注意事项,需要的朋友参考一下 利用OpenCV练习读取图片的时候,图片总是一闪而过,不利于观察,这个时候需要利用到waitKey函数。 waitKey函数:用来等待按键,当用户按下按键后,该语句会被执行,并获取返回值。 语法格式为retval=cv2

  • 本文向大家介绍快速解决Canvas.toDataURL 图片跨域的问题,包括了快速解决Canvas.toDataURL 图片跨域的问题的使用技巧和注意事项,需要的朋友参考一下 如题,在将页面的图片地址进行本地输出时(Html2Canvas.js),因不同源存在跨域问题,会出现toDataURL访问权限问题: 【Redirect at origin 'http://sub1.xx.com' has

  • 本文向大家介绍Android Webview滑进出屏幕闪烁的解决方法,包括了Android Webview滑进出屏幕闪烁的解决方法的使用技巧和注意事项,需要的朋友参考一下 前言 在使用Webview进行滑动操作时,从屏幕可见区域外向内滑动时,会出现webview区域闪烁的问题(反之也是),本文将提供一种解决方案。 问题图示 xml布局: 可以看到,NestedScrollView嵌套webview

  • 本文向大家介绍wxPython之解决闪烁的问题,包括了wxPython之解决闪烁的问题的使用技巧和注意事项,需要的朋友参考一下 利用Python生成PDF文件时,对比了fpdf和reportlab两个库。fpdf最新更新还是2015年, 另外reportlab的资料网上更多一些。所以选择使用reportlab。 pdfgen pdfgen包是生成PDF文档最底层的接口。一个pdfgen编程实质是一