ListView的动态加载,想必大家在网上都看过很多资料了。我在这里也不罗嗦,提供非常简单的Demo给一些需要的人。
这个Demo里面只有两个部分,
Activity做显示,以及一个Factory创建信息。
MainActivity.java
package com.demo;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AbsListView.OnScrollListener;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
public class MainActivity extends Activity implements OnScrollListener,OnItemClickListener {
private ListView listView;
private List<String> currentData;//当前视图显示的数据
private CustomAdapter customadapter;//自定义适配器
private View loadingView;//加载视图的布局
private int currentPage = 1;//当前页,默认为1
private int pageSize = 10;//每页显示十条信息
private int last_item_position;//最后item的位置
private boolean isLoading = false;//是否加载过,控制加载次数
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
listView=(ListView)findViewById(R.id.lv_id);
//加载视图布局
loadingView = LayoutInflater.from(this).inflate(R.layout.list_page_load, null);
//创建当前用于显示视图的数据
currentData=CreateDataFactory.createUpdateData(currentPage,pageSize);
//添加底部加载视图
listView.addFooterView(loadingView);
//初始化适配器
customadapter=new CustomAdapter();
listView.setAdapter(customadapter);
//滚动条监听
listView.setOnScrollListener(this);
//ListView监听
listView.setOnItemClickListener(this);
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
last_item_position = firstVisibleItem + visibleItemCount - 1;
if(last_item_position==totalItemCount-2){//这里控制当焦点落在某一个位置时,开始加载.
//当前是在第9个位置开始加载,改为totalItemCount-1
//则会在第10个位置开始加载
System.out.println("开始加载..");
Toast.makeText(MainActivity.this, "第 "+currentPage+" 页", Toast.LENGTH_LONG).show();
if(!isLoading){
new Thread(){
public void run() {
isLoading = true;
//开启一个线程加载数据,否则会堵塞当前线程
updateCurrendData();
//发送一个消息,通知数据加载完成
loadingHandler.sendEmptyMessage(0);
}
}.start();
}
}
//当ListView没有FooterView时,添加FooterView(---loadingView---)
if(listView.getFooterViewsCount()==0){
listView.addFooterView(loadingView);
}
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
// TODO Auto-generated method stub
}
Handler loadingHandler = new Handler(){
public void handleMessage(android.os.Message msg) {
//修改adapter count
customadapter.count = currentPage*pageSize;
//更新
customadapter.notifyDataSetChanged();
//消除MSG
loadingHandler.removeMessages(0);
//删除FooterView
listView.removeFooterView(loadingView);
//进入下一页,此时视图未加载.
isLoading = false;
};
};
//添加List元素
private void updateCurrendData(){
//模拟联接网络以及从网络中获取数据花费的时间
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//更新一次,当前页加1
currentPage++;
//获取当前要更新的数据
List<String> updateDataList = CreateDataFactory.createUpdateData(currentPage, pageSize);
//需要更新的数据加入当前数据集合
for(String itemData:updateDataList){
currentData.add(itemData);
}
}
class CustomAdapter extends BaseAdapter{
int count=currentData.size();
@Override
public int getCount() {
// TODO Auto-generated method stub
return count;
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view=LayoutInflater.from(MainActivity.this).inflate(R.layout.list_page_item, null);
TextView tv_content = (TextView) view.findViewById(R.id.tv_content);
tv_content.setText(currentData.get(position));
return view;
}
}
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
// TODO Auto-generated method stub
}
}
CreateDataFactory.java
package com.demo;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class CreateDataFactory {
public static List<String> createUpdateData(int currentPage,int pageSize){
List<String> list=new ArrayList<String>();
for(int i=(currentPage-1)*pageSize;i<currentPage*pageSize;i++){
list.add((i+1)+". 走在风中,今天阳光突然很温柔.");
}
return list;
}}
CreateDataFactory模拟了网络调取API获取信息的实现,以及API数据分页。对于ListView的优化,以及滑动事件的监听还没去完善。不过这些代码对想学习ListView的动态加载,以及分页显示来说以及够了。
分享到:
相关推荐
朋友你是不是也想对其优化,形成动态加载? 如果你也有过这样的想法,那么我们是同路人! 通过查看ListView的API,我们似乎找不到这样的接口来满足我们的需求,怎么办呢?不要忘记,我们不只是程序员,我们同样也...
ListView底部加载更多demo,实现数据的分页加载小demo,适合初学者下载学习
可以直接放进项目运行的最简单的listview上拉刷新下拉加载demo,只要修改添加你的数据源就可以用,适合初学者
BitMap高效显示策略(二):在ListView上异步加载网络图片 http://blog.csdn.net/ohehehou/article/details/40678741
自定义ListView实现下拉刷新+加载更多功能Demo
内容:上拉加载的整个Demo工程源码 功能:实现ListView上拉加载,列表页脚提示加载状态
Android listview实现图片的异步加载Demo.zip
这是一个包含异步加载、网络编程、JSON解析、LruCache图片缓存的简易的ListView图文混排Demo.rar,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考学习。
简单的listview加载多种子布局的demo;demo里只用了三种布局,比较简单易懂;
android listView图片异步加载(拖动时不加载,双缓存)
android listview demo 下拉加载更多 已调试通过。
自定义的listview,效果挺不错的,刷新时显示上次刷新时间
wpf 实现listview列表加载demo
一种listview 下拉加载的方法 可以尝试尝试
ListView的demo,拖曳加载。先加载20个,拖曳后再加载20
点击button动态加载listView的demo。
我们在看微博或是到网上商城如淘宝中购物时,每一个商家都会有很多商品,如果把某商家的所有商品都一次性加载过来,会造成手机卡顿,影响用户体验,所以每次加载少量数据,使用分页的形式,分多页加载,会很好的提高...
android ListView 分页加载 详情可以参考博客:http://blog.csdn.net/wild46cat/article/details/52620370
android中listview滚动加载的demo,通过监听事件实现滑动到底部自动加载更多数据