Android Listview滑动时不加载数据 停止时加载数据

 更新时间:2017年03月13日 14:13:16   作者:Sean_帅恩  
这篇文章主要为大家详细介绍了Android Listview滑动时不加载数据,停止时加载数据,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Listview滑动时不加载数据 停止时加载数据的具体代码,供大家参考,具体内容如下

数据源配置(Adapter)

package com.zhengsonglan.listview_loading.adapter;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import com.nostra13.universalimageloader.core.ImageLoader;
import com.zhengsonglan.listview_loading.R;
import com.zhengsonglan.listview_loading.entity.UserEnity;

import java.util.List;

/**
 *
 */
public class MyAdapter extends BaseAdapter {
 Context context;
 LayoutInflater inflater;
 List<UserEnity> lists;

 private boolean scrollState=false;

 public void setScrollState(boolean scrollState) {
  this.scrollState = scrollState;
 }


 public MyAdapter(Context context, List<UserEnity> lists) {
  this.context=context;
  this.inflater=LayoutInflater.from(context);
  this.lists=lists;
 }

 @Override
 public int getCount() {
  return lists!=null?lists.size():0;
 }

 @Override
 public Object getItem(int position) {
  return lists.get(position);
 }

 @Override
 public long getItemId(int position) {
  return position;
 }

 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
  ViewHolder viewHolder;
  if (convertView == null) {
   convertView=inflater.inflate(R.layout.main_item,null,true);
   viewHolder=new ViewHolder();
   viewHolder.iv_icon= (ImageView) convertView.findViewById(R.id.main_item_iv_icon);
   viewHolder.tv_name= (TextView) convertView.findViewById(R.id.main_item_tv_name);
   convertView.setTag(viewHolder);
  } else {
   viewHolder= (ViewHolder) convertView.getTag();
  }


  UserEnity userEnity=lists.get(position);

  String img_url=userEnity.getIcon();
  if (!scrollState){
   viewHolder.tv_name.setText(userEnity.getName());
   viewHolder.tv_name.setTag(null);
   ImageLoader.getInstance().displayImage(img_url,viewHolder.iv_icon);
   viewHolder.iv_icon.setTag("1");

  }else{
   viewHolder.tv_name.setText("加载中");
   viewHolder.tv_name.setTag(userEnity.getName());
   viewHolder.iv_icon.setTag(img_url);
   viewHolder.iv_icon.setImageResource(R.mipmap.ic_launcher);

  }
  return convertView;

 }

 static class ViewHolder{
  TextView tv_name;
  ImageView iv_icon;
 }
}

这个Adapter中重要的代码如下:

//定义当前listview是否在滑动状态
private boolean scrollState=false;
public void setScrollState(boolean scrollState) {
 this.scrollState = scrollState;
}
//实体类
UserEnity userEnity=lists.get(position);

if (!scrollState){//如果当前不是滑动的状态,我们填充真数据
   //填充数据
   viewHolder.tv_name.setText(userEnity.getName());
   //设置Tag中数据为空表示数据已填充
   viewHolder.tv_name.setTag(null);
   //加载图片
   ImageLoader.getInstance().displayImage(img_url,viewHolder.iv_icon);
   //设置tag为1表示已加载过数据
   viewHolder.iv_icon.setTag("1");

}else{//如果当前是滑动的状态,我们填充假数据
   viewHolder.tv_name.setText("加载中");
   //将数据name保存在Tag当中
   viewHolder.tv_name.setTag(userEnity.getName());
   //将数据image_url保存在Tag当中
   viewHolder.iv_icon.setTag(img_url);
   //设置默认显示图片(最好是本地资源的图片)
   viewHolder.iv_icon.setImageResource(R.mipmap.ic_launcher);

}

设置监听

ok,我们在看看Activity中的代码,主要是监听listview的onscrolllistener方法

@Override
 public void onScrollStateChanged(AbsListView view, int scrollState) {
  switch (scrollState){

   case AbsListView.OnScrollListener.SCROLL_STATE_IDLE://停止滚动
   {
    //设置为停止滚动
    myAdapter.setScrollState(false);
    //当前屏幕中listview的子项的个数
    int count = view.getChildCount();
    Log.e("MainActivity",count+"");

    for (int i = 0; i < count; i++) {
     //获取到item的name
     TextView tv_name = (TextView) view.getChildAt(i).findViewById(R.id.main_item_tv_name);
     //获取到item的头像
     ImageView iv_show= (ImageView) view.getChildAt(i).findViewById(R.id.main_item_iv_icon);

     if (tv_name.getTag() != null) { //非null说明需要加载数据
      tv_name.setText(tv_name.getTag().toString());//直接从Tag中取出我们存储的数据name并且赋值
      tv_name.setTag(null);//设置为已加载过数据
     }

     if (!iv_show.getTag().equals("1")){//!="1"说明需要加载数据
      String image_url=iv_show.getTag().toString();//直接从Tag中取出我们存储的数据image——url
      ImageLoader.getInstance().displayImage(image_url, iv_show);//显示图片
      iv_show.setTag("1");//设置为已加载过数据
     }
    }
    break;
   }
   case AbsListView.OnScrollListener.SCROLL_STATE_FLING://滚动做出了抛的动作
   {
    //设置为正在滚动
    myAdapter.setScrollState(true);
    break;
   }

   case AbsListView.OnScrollListener.SCROLL_STATE_TOUCH_SCROLL://正在滚动
   {
    //设置为正在滚动
    myAdapter.setScrollState(true);
    break;
   }
  }
 }

最后记得给listview加上滑动的监听

listview.setOnScrollListener(this);

效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android实现长图文截图功能实例代码

    Android实现长图文截图功能实例代码

    这篇文章主要给大家介绍了关于Android实现长图文截图功能的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • 一文详解Android FCM接入

    一文详解Android FCM接入

    这篇文章主要为大家介绍了Android FCM接入详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Android选择与上传图片之PictureSelector教程

    Android选择与上传图片之PictureSelector教程

    这篇文章主要介绍了在Android中对于图片的选择与上传方法,本文介绍了PictureSelector的相关使用教程,学习Android的同学进来看看吧
    2021-08-08
  • Android Broadcast原理分析之registerReceiver详解

    Android Broadcast原理分析之registerReceiver详解

    这篇文章主要介绍了Android Broadcast原理分析之registerReceiver详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 解决android6.0以上不能读取外部存储权限的问题

    解决android6.0以上不能读取外部存储权限的问题

    今天小编就为大家分享一篇解决android6.0以上不能读取外部存储权限的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • Android9.0 SystemUI 网络信号栏定制修改的流程解析

    Android9.0 SystemUI 网络信号栏定制修改的流程解析

    这篇文章主要介绍了Android9.0 SystemUI 网络信号栏定制修改的流程,本文通过图文实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-11-11
  • Android实现apk插件方式换肤的实例讲解

    Android实现apk插件方式换肤的实例讲解

    在本篇文章里小编给大家整理的是关于Android实现apk插件方式换肤的实例代码以及相关知识点,有需要的朋友们学习下。
    2019-10-10
  • Android播放音乐案例分享

    Android播放音乐案例分享

    这篇文章主要为大家分享了Android播放音乐案例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09
  • Android自定义ImageView实现圆角功能

    Android自定义ImageView实现圆角功能

    这篇文章主要为大家详细介绍了Android自定义ImageView实现圆角功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • 详解Flutter WebView与JS互相调用简易指南

    详解Flutter WebView与JS互相调用简易指南

    这篇文章主要介绍了详解Flutter WebView与JS互相调用简易指南,分为JS调用Flutter和Flutter调用JS,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04

最新评论