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

转自:http://blog.csdn.net/shineflowers/article/details/41744241

在Android中有很多时候会选择用ListView加载数据,有的是分批加载,比如每次加载20条,100条就要加载5次,如果一次性加载100条,ListView加载就会变慢,如果是有图片的话,一是浪费流量,二是item中带图片会出现错位的问题l,ListView加载数据目前好多App的做法

1. 分批加载,滑动到底部自动更新

2. 滑动到底部,手动的点击加载更多

3. 下拉刷新 + 底部加载更多

今天实现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;
        }
    }
}
时间: 2024-08-21 14:20:52

[转]ListView滚动到底部自动加载数据的相关文章

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

在android中listvieww加载数据,有的是分批加载,比如每次加载20条,100条就要加载5次,如果一次性加载100条,listview加载就变的慢,如果是有图片的话,一时浪费流量,二是item中带图片会出现错位的问题,listview加载数据目前好多app做法 一:分批加载 滑动到底部自动更新 二:滑动到底部 手动的点击加载更多 三:下拉刷新+底部加载更多 今天就讲下listview滑动到底部自动更新 分析:监听listview的滑动事件,判断listview是否滑动到底部,然后去加载

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

页面滚动到底部自动加载下一页功能的实现,效果见本博首页 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内部的数据变化

探索SwipeRefreshLayout配合自定义ListView完成下拉刷新、滑到底部自动加载更多

在Android开发过程中经常需要实现上下拉刷新功能,Google推出的下拉刷新控件SwipeRefreshLayout(彩虹条),由于官方版本只有下拉刷新而没有上拉加载更多的功能,很多人也尝试在这个基础上进行改写.今天尝试一下使用SwipeRefreshLayout配合自定义ListView实现下拉刷新.滑到底部自动加载更多的功能. 效果图如下所示,在进入页面的时候加载自动刷新,滑到底部自动加载更多,当数据已经加载完成则显示已经加载完成,,否则上拉任可继续加载 先贴一下项目结构图吧,这样可能对