LIstview滑动时不加载图片,停止时加载!

Posted 牛皮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LIstview滑动时不加载图片,停止时加载!相关的知识,希望对你有一定的参考价值。

//参照 http://blog.csdn.net/yy1300326388/article/details/45153813 

public
class CarWashDistanceAdapter extends BaseAdapter { private static final String TAG = "CarWashDistanceAdapter"; private Context context; private MyDialog myDialog; private ArrayList<FourServiceBean> arrayList; private boolean scrollState=false; private float density = 1.5f; //定义当前listview是否在滑动状态 public void setScrollState(boolean scrollState) { this.scrollState = scrollState; } public CarWashDistanceAdapter(Context context, ArrayList<FourServiceBean> arrayList) { this.context = context; this.arrayList=arrayList; } public void refresh( ArrayList<FourServiceBean> arrayList) { this.arrayList=arrayList; notifyDataSetChanged(); } @Override public int getCount() { return arrayList.size(); } @Override public Object getItem(int position) { return arrayList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(final int position, View convertView, ViewGroup parent) { Hodler hodler; if (convertView == null) { hodler = new Hodler(); convertView = View.inflate(context, R.layout.listview_car_wash_item, null); hodler.mImageView = (ImageView) convertView.findViewById(R.id.car_wash_item_imageview); hodler.mTelImageview = (ImageView) convertView.findViewById(R.id.car_wash_item_phone_imageview); hodler.mTitleTextView = (TextView) convertView.findViewById(R.id.car_wash_item_title_textview); hodler.mDistanceTextView = (TextView) convertView.findViewById(R.id.car_wash_item_distance_textview); hodler.mSubTextView = (TextView) convertView.findViewById(R.id.car_wash_item_subtitle_textview); hodler.relativeLayout = (RelativeLayout) convertView.findViewById(R.id.car_wash_item_relativelayout); hodler.mRatingBar = (RatingBar) convertView.findViewById(R.id.car_wash_item_ratingbar); convertView.setTag(hodler); } else { hodler = (Hodler) convertView.getTag(); } hodler.mTitleTextView.setText(arrayList.get(position).getShop_name()); hodler.mSubTextView.setText(arrayList.get(position).getDetail_address()); if(arrayList.get(position).getDistance()/1000 <= 1){ hodler.mDistanceTextView.setText((new DecimalFormat("0").format(arrayList.get(position).getDistance()) + "m")); }else { hodler.mDistanceTextView.setText((new DecimalFormat("0.00").format(arrayList.get(position).getDistance()/1000)+ "km")); } if(arrayList.get(position).getScore()!=null ) { hodler.mRatingBar.setRating(Float.valueOf(arrayList.get(position).getScore())); } final String[] sourceStrArray = arrayList.get(position).getTel_num_list().split(","); hodler.mTelImageview.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { myDialog = new MyDialog(context, R.style.MyDialog, new MyDialog.LeaveMyDialogListener() { @Override public void onClick(View view) { switch (view.getId()) { case R.id.mydialog_clear: myDialog.dismiss(); break; } } }, Arrays.asList(sourceStrArray),myDialog); myDialog.show(); } });
//这获取的是图片的url String url
= arrayList.get(position).getShop_pic_url(); if (!scrollState){ //如果当前不是滑动的状态,我们填充真数据 //加载图片 if(url!= null) {
//这是我添加图片的方法 THttpOpenHelper.newInstance().setImageBitmap(hodler.mImageView, url,(
int)(100 * density), (int)(75 * density), R.drawable.icon_default1, R.drawable.icon_default1); //设置tag为1表示已加载过数据 hodler.mImageView.setTag("1"); }else{ hodler.mImageView.setImageResource(R.drawable.icon_default1); hodler.mImageView.setTag("1"); } }else{ //如果当前是滑动的状态,我们填充假数据 //将数据image_url保存在Tag当中 hodler.mImageView.setTag(url); //设置默认显示图片(最好是本地资源的图片) hodler.mImageView.setImageResource(R.drawable.icon_default1); } return convertView; } private class Hodler { ImageView mImageView; ImageView mTelImageview; TextView mTitleTextView; TextView mSubTextView; TextView mDistanceTextView; RelativeLayout relativeLayout; RatingBar mRatingBar; } }

以上是Adapter中的代码:其中重要的就是

  //定义当前listview是否在滑动状态
    public void setScrollState(boolean scrollState) {
        this.scrollState = scrollState;
    }

还有这段是给imageview赋值的操作

 //这获取的是图片的url
        String url = arrayList.get(position).getShop_pic_url();
        if (!scrollState){
            //如果当前不是滑动的状态,我们填充真数据
            //加载图片
            if(url!= null) {
                //这是我添加图片的方法
                THttpOpenHelper.newInstance().setImageBitmap(hodler.mImageView, url,(int)(100 * density), (int)(75 * density), R.drawable.icon_default1, R.drawable.icon_default1);
                //设置tag为1表示已加载过数据
                hodler.mImageView.setTag("1");
            }else{
                hodler.mImageView.setImageResource(R.drawable.icon_default1);
                hodler.mImageView.setTag("1");
            }
        }else{
            //如果当前是滑动的状态,我们填充假数据
            //将数据image_url保存在Tag当中
              hodler.mImageView.setTag(url);
                //设置默认显示图片(最好是本地资源的图片)
                hodler.mImageView.setImageResource(R.drawable.icon_default1);
          }

最后在Activity中添加

     mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
                    @Override
                    public void onScrollStateChanged(AbsListView view, int scrollState) {
                        switch (scrollState){
                             //停止滚动
                            case AbsListView.OnScrollListener.SCROLL_STATE_IDLE:
                            {
                                //设置为停止滚动
                                carWashDistanceAdapter.setScrollState(false);
                                //当前屏幕中listview的子项的个数
                                int count = view.getChildCount();
                                for (int i = 0; i < count; i++) {
                                    //获取到item的图片显示的Imageview控件
                                    ImageView iv_show= (ImageView) view.getChildAt(i).findViewById(R.id.car_wash_item_imageview);
                                    if (!iv_show.getTag().equals("1")){//如果等于1说明图片资源已加载过,不等于说明没有去getTag()的图片url
                                      
                               //直接从Tag中取出我们存储的数据image——url
                                         String image_url = iv_show.getTag().toString();
                                         if (image_url != null) {//这个判断是防止图片的url是否为空,为空的话给默认图片。
                                             THttpOpenHelper.newInstance().setImageBitmap(iv_show, image_url, R.drawable.icon_default1, R.drawable.icon_default1);
                                             //设置为已加载过数据
                                             iv_show.setTag("1");
                                         } else {
                                             iv_show.setBackgroundResource(R.drawable.icon_default1);
                                             iv_show.setTag("1");
                                         }
                                    
                                    }
                                }
                                break;
                            }
                            //滚动做出了抛的动作
                            case AbsListView.OnScrollListener.SCROLL_STATE_FLING:
                            {
                                //设置为正在滚动
                                carWashDistanceAdapter.setScrollState(true);
                                break;
                            }
                             //正在滚动
                            case AbsListView.OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:
                            {
                                //设置为正在滚动
                                carWashDistanceAdapter.setScrollState(true);
                                break;
                            }
                        }
                    }

                    @Override
                    public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {

                    }
                });

 

以上是关于LIstview滑动时不加载图片,停止时加载!的主要内容,如果未能解决你的问题,请参考以下文章

Flutter ListView优化(滑动不加载,停止滑动加载)

使用Lrucache,图片滑动时使用默认图片,停止时加载

Android ListView 全面优化

Android性能优化--OOM

图片懒加载使用

React Image加载图片过大导致ListView滑动卡顿