listview滚动到底部自动加载数据

在android中listvieww加载数据,有的是分批加载,比如每次加载20条,100条就要加载5次,如果一次性加载100条,listview加载就变的慢,如果是有图片的话,一时浪费流量,二是item中带图片会出现错位的问题,listview加载数据目前好多app做法

一:分批加载 滑动到底部自动更新

二:滑动到底部 手动的点击加载更多

三:下拉刷新+底部加载更多

今天就讲下listview滑动到底部自动更新

分析:监听listview的滑动事件,判断listview是否滑动到底部,然后去加载数据

代码如下:

public class MainActivity extends Activity {
	private ListView listview;
	private List<String> datas;
	private LayoutInflater inflater;
	private MyAdapter adapter;
	private List<String>  contents;
	private int count = 0;
	private View footView;
	private Handler handler = new Handler();
	int lastItem;
	private RelativeLayout loading;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		initData();
		inflater = LayoutInflater.from(this);
		listview = (ListView) findViewById(R.id.listview);
		adapter = new MyAdapter();
		footView = inflater.inflate(R.layout.footer, null);
		loading = (RelativeLayout) footView.findViewById(R.id.loading);
		//listview的addFooterView()添加view到listview底部一定要加在listview.setAdapter(adapter);这代码前面
		listview.addFooterView(footView);
		listview.setAdapter(adapter);
		//添加listview滚动监听
		listview.setOnScrollListener(new OnScrollListener() {
			//AbsListView view 这个view对象就是listview
			@Override
			public void onScrollStateChanged(AbsListView view, int scrollState) {
				if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
					if (view.getLastVisiblePosition() == view.getCount() - 1) {
						loadData();
					}
				}
			}
			@Override
			public void onScroll(AbsListView view, int firstVisibleItem,
					int visibleItemCount, int totalItemCount) {
				   lastItem = firstVisibleItem + visibleItemCount - 1 ;
			}
		});
	}
	protected void loadData() {
		loading.setVisibility(View.VISIBLE);
		handler.postDelayed(new Runnable() {
			@Override
			public void run() {
				 load();
				 loading.setVisibility(View.GONE);
				 adapter.notifyDataSetChanged();
			}
		}, 5000);
	}
	protected void load() {
		int count=adapter.getCount()+1;
    	for(int i=count;i<count+20;i++){
    		 contents.add("加载数据:::"+i);
    	}
	}
	private void initData() {
		contents = new ArrayList<String>();
		for(int i=1;i<20;i++){
			contents.add("加载数据:::"+i);
		}
	}

	class MyAdapter extends BaseAdapter{
		@Override
		public int getCount() {
			return contents.size();
		}
		@Override
		public Object getItem(int position) {
			return contents.get(position);
		}

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

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			ViewHolder holder;
			if(convertView==null){
				convertView = inflater.inflate(R.layout.item, parent, false);
				holder = new ViewHolder();
				holder.tvContent = (TextView) convertView.findViewById(R.id.tvContent);
			    convertView.setTag(holder);
			}else{
				holder = (ViewHolder) convertView.getTag();
			}
			holder.tvContent.setText(contents.get(position));
			return convertView;
		}
		class ViewHolder{
			TextView tvContent;
		}
	}
}

时间: 2025-01-03 15:35:11

listview滚动到底部自动加载数据的相关文章

[转]ListView滚动到底部自动加载数据

转自:http://blog.csdn.net/shineflowers/article/details/41744241 在Android中有很多时候会选择用ListView加载数据,有的是分批加载,比如每次加载20条,100条就要加载5次,如果一次性加载100条,ListView加载就会变慢,如果是有图片的话,一是浪费流量,二是item中带图片会出现错位的问题l,ListView加载数据目前好多App的做法 1. 分批加载,滑动到底部自动更新 2. 滑动到底部,手动的点击加载更多 3. 下拉

页面滚动到底部自动加载下一页功能的实现

页面滚动到底部自动加载下一页功能的实现,效果见本博首页 1.endlesspage.js文件内容 var gPageSize = 10; var i = 1; //设置当前页数,全局变量 var finished = false; var dataUrl = ''; $(function () { //根据页数读取数据 function getData(pagenumber) { //console.log(i); $.get(dataUrl, { pagesize: gPageSize, p:

关于JQuery实现滚动到底部自动加载中应当注意的地方

在滚动到底部自动加载时常常用到以下代码 container.bind('scroll', function(){ if(container.scrollTop() + container.height() >= container.prop("scrollHeight")){ loadNextPage(); } }); 其中container.prop("scrollHeight") 就相当于 container.get(0).scrollHeight 用于获

滚动到底部自动加载新内容

$(window).on('scroll',function(){ if($(window).height()+$(window).scrollTop()>=$(document).height()){ console.log("到达底部"); //这里是要加载的数据 } }); console.log('整个网页的高度'+$(document).height()); //整个网页的高度console.log('浏览器可视窗口的高度'+ $(window).height()) ;

网页滚动到底部自动加载

<html> <head> <style type="text/css"> #top_div{ position:fixed; bottom:80px; right:0; display:none; } </style> <script type="text/javascript"> var i=0; window.onscroll = function(){ var t = document.docume

ionic ion-list 滑到底部自动加载数据案例

<ion-content> <ion-list> <ion-item ng-repeat="item in items track by $index"> <p>{{item}}</p> </ion-item> <ion-infinite-scroll on-infinite="addItems()"></ion-infinite-scroll> </ion-lis

Android数据分批加载-滑动到底部自动加载列表

Android数据分批加载-滑动到底部自动加载列表 2014年5月9日 本博文介绍如何进行数据分批加载,在应用开发当中会经常使用到ListView,点击更多加载数据是我们经常简单,为了提供用户体验,当用户将列表滚动到底部自动加载数据,这样的形式用得比较多. 下面给大家提供的例子是,每次模拟20条数据,滑动到底部时再请求20条数据直到请求到限定页数为止 具体代码实现: /08_Datapageload/src/com/wwj/datapageload/MainActivity.java packa

分享大麦UWP版本开发历程-03.GridView或ListView 滚动底部自动加载后续数据

今天跟大家分享的是大麦UWP客户端,在分类.订单或是搜索时都用到的一个小技巧,技术粗糙大神勿喷. 以大麦分类举例,默认打开的时候,会为用户展示20条数据,当用户滚动鼠标或者使用手势将列表滑动到倒数第二行的位置时,自动加载后续20条数据.提高启动速度的同时稍稍节省用户的流量. 其他的就不说了,直接进入代码阶段. Step1,界面部分很简单,我放弃了Gridvew自己的滚动,在外面包上了一个ScrollViewr,监听ViewChanged事件(这样代码比较简单,直接用GridView内部的数据变化

android Listview下滑,自动加载数据.修改多处地方,去除重绘listvew,防止闪烁

感谢其他大神的的源码支持 我仅在此源码上进行修改以及注释. 使用方法: //设置加载分页数据监听 loadingListView.setOnLoadMoreListener(new OnLoadMoreListener() { public void onLoadMore() { if(page<3){ }else{ loadingListView.onLoadMoreComplete();//移除加载更多布局,加载完成 loadingListView.setIsEnable(false); /