Listview分页加载

//=========主页面=============

package com.example.fenye;

import java.util.ArrayList;
import java.util.List;

import com.example.fenye.adapter.MyAdapter;
import com.example.fenye.bean.News;

import android.os.Bundle;
import android.os.Handler;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.Button;
import android.widget.ListView;
import android.widget.Toast;

public class MainActivity extends Activity implements OnScrollListener {
    private List<News> news=new ArrayList<News>();

private ListView lv;
    private View loadmoreView;
    private Button bt_loadmore;
    private int visibleLastIndex =0;//最后的可视项索引  
    private int visibleItemCount;// 当前窗口可见项总数  
    private int datasize=38;//模拟数据集的条数
    
    private Handler handler=new Handler();

private MyAdapter adapter;

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        
        //找到加载更多的布局
       loadmoreView = getLayoutInflater().inflate(R.layout.loadmore, null);
       //找到加载更多的控件
       bt_loadmore = (Button) loadmoreView.findViewById(R.id.bt_loadmore);
       //设置加载更多的监听
       bt_loadmore.setOnClickListener(new OnClickListener() {
        
        @Override
        public void onClick(View v) {
            bt_loadmore.setText("正在加载中...");//设置按钮文字
            //使用handler发送一个延迟消息
            handler.postDelayed(new Runnable() {
                
                @Override
                public void run() {
                    //加载更多数据
                    loadMoreData();
                    //刷新适配器
                    adapter.notifyDataSetChanged();
                    bt_loadmore.setText("查看更多...");//恢复按钮文字
                }

}, 2000);
            
            
        }
    });
     //找到控件
       lv = (ListView) findViewById(R.id.lv);
       lv.addFooterView(loadmoreView);
       //初始化数据
       initializeAdapter();
       //设置适配器
       adapter = new MyAdapter(news, this);
       lv.setAdapter(adapter);
       lv.setOnScrollListener(this);
    }
    //加载更多数据
    private void loadMoreData() {
        int count=adapter.getCount();
        if (count+10<datasize) {
            for (int i = count+1; i <=count+10; i++) {
                News item=new News();
                item.setName("姓名:"+i);
                adapter.addNewsItem(item);
            }
        }else{
            for (int i = count+1; i <datasize; i++) {
                News item=new News();
                item.setName("姓名:"+i);
                adapter.addNewsItem(item);
            }
        }
        
    }

//初始化数据
    private void initializeAdapter() {
        for (int i = 0; i <=10; i++) {
            News newss=new News();
            newss.setName("姓名:"+i);
            news.add(newss);
        }
        
    }

//滑动监听
    @Override
    public void onScrollStateChanged(AbsListView view, int scrollState) {
        int itemsLaseIndex=adapter.getCount()-1;//数据集最后一项的索引  
        int lastIndex=itemsLaseIndex+1;
        if (scrollState==OnScrollListener.SCROLL_STATE_IDLE&&visibleLastIndex==lastIndex) {
            // 如果是自动加载,可以在这里放置异步加载数据的代码
        }
        
    }
    //滑动监听
    @Override
    public void onScroll(AbsListView view, int firstVisibleItem,
            int visibleItemCount, int totalItemCount) {
        visibleItemCount=visibleItemCount;
        visibleLastIndex=firstVisibleItem+visibleItemCount-1;
         //如果所有的记录选项等于数据集的条数,则移除列表底部视图
        if (totalItemCount==datasize+1) {
            lv.removeFooterView(loadmoreView);
            Toast.makeText(this, "数据全部加载完!", 0).show();
        }
    }
    
}

//========创建一个MyAdapter  继承  BaseAdapter====================

package com.example.fenye.adapter;

import java.util.List;

import com.example.fenye.R;
import com.example.fenye.bean.News;

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

public class MyAdapter extends BaseAdapter{
    private List<News> news;
    private Context context;

public MyAdapter(List<News> news, Context context) {
        super();
        this.news = news;
        this.context = context;
    }

@Override
    public int getCount() {
        // TODO Auto-generated method stub
        return news.size();
    }

@Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub
        return news.get(position);
    }

@Override
    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return position;
    }

@Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder;
        News newss=news.get(position);
        if (convertView==null) {
            convertView=View.inflate(context, R.layout.list_item, null);
            holder=new ViewHolder();
            holder.name=(TextView) convertView.findViewById(R.id.tv_name);
            convertView.setTag(holder);
        }
        holder=(ViewHolder) convertView.getTag();
        holder.name.setText(newss.getName());
        return convertView;
    }
    static class ViewHolder{
        public TextView name;
    }
    public void addNewsItem(News newsitem){
        news.add(newsitem);
    }

}

//===========bean包==创建一个News类======================

package com.example.fenye.bean;

public class News {
    private String name;

public News(String name) {
        super();
        this.name = name;
    }

public News() {
        super();
    }

public String getName() {
        return name;
    }

public void setName(String name) {
        this.name = name;
    }

@Override
    public String toString() {
        return "News [name=" + name + "]";
    }

}

//=============main布局文件 ==========================

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >

<ListView android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:id="@+id/lv"></ListView>

</RelativeLayout>

//=========list_item布局文件======================

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <TextView android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tv_name"/>

</LinearLayout>

//=========loadmore布局文件====================

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <Button android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/bt_loadmore"
        android:text="查看更多..."/>

</LinearLayout>

时间: 2024-10-09 15:35:13

Listview分页加载的相关文章

Android ListView分页加载(服务端+android端)Demo

Android ListView分页加载功能 在实际开发中经常用到,是每个开发者必须掌握的内容,本Demo给出了服务端+Android端的两者的代码,并成功通过了测试. 服务端使用MyEclipse,Android端使用Eclipse. 实现效果图: 服务端一共100条数据,共分四页,每页有25条数据. 源代码: 服务端: 需要导入图中这几个jar包. 在运行Android端代码前,需要开启服务端: 下面先给出服务端的代码: 类EmpDataSource: package com.android

ListView分页加载数据

在android软件开发中,ListView是一种经常被用到的组件.当需要用到列表显示的时候,通常都会用到.而使用的过程中也可能出现一些问题.比如,一次性加载过多的Item对于手机有限的内存来说,是一种负担.于是就有了分页加载的技术,一般的说,分页的使用方式有两种,一是在滑动到底部的时候,自动加载下一部分的内容.另一种则是在底部添加一个类似按钮的控件,点击后加载内容.这里介绍的是第一种.同样的,代码来自github,网址是:https://github.com/nicolasjafelle/Pa

Android中ListView分页加载数据-转

Android应用开发中,采用ListView组件来展示数据是很常用的功能,当一个应用要展现很多的数据时,一般情况下都不会把所有的数据一次就展示出来,而是通过分页的形式来展示数据,个人觉得这样会有更好的用户体验.因此,很多应用都是采用分批次加载的形式来获取用户所需的数据.例如:微博客户端可能会在用户滑动至列表底端时自动加载下一页数据,也可能在底部放置一个"查看更多"按钮,用户点击后,加载下一页数据. 下面通过一个Demo来展示ListView功能如何实现:该Demo通过在ListVie

Android中ListView分页加载数据

熟悉Android的朋友们都知道,不管是微博客户端还是新闻客户端,都离不开列表组件,可以说列表组件是Android数据展现方面最重要的组件,我们今天就要讲一讲列表组件ListView加载数据的相关内容.通常来说,一个应用在展现大量数据时,不会将全部的可用数据都呈现给用户,因为这不管对于服务端还是客户端来说都是不小的压力,因此,很多应用都是采用分批次加载的形式来获取用户所需的数据.比如:微博客户端可能会在用户滑动至列表底端时自动加载下一页数据,也可能在底部放置一个“加载更多”按钮,用户点击后,加载

ListView动态加载数据分页(使用Handler+线程和AsyncTask两种方法)

ListView动态加载数据分页(使用Handler+线程和AsyncTask两种方法)

带表头 固定列可左右上下滑动的可分页加载的ListView

项目描述: 最近做项目,遇到一个问题,就是要求ListView既要有表头,点击表头从能够对特定的列进行排序,并且要求固定第一列,右边的其他列不固定,能够向左滑动的时候,收缩到左侧,向右滑动的时候,显示已经收缩的列,总之就是满足一个需求,一个表里面有很多个列的时候,单个屏幕显示不完所有的列,因此,就做一个可收缩的列表,用于在一个控件里面显示完表中所有的字段. 小的我参考了网上的代码,名字为demoHListView(大家可以到网上搜索下载,或者在我共享的代码中去下载),是用观察者模式来实现的效果,

android UI进阶之实现listview的分页加载

 分享了下拉刷新,这是一个用户体验非常好的操作方式.新浪微薄就是使用这种方式的典型. 还有个问题,当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了.通过分页分次加载数据,用户看多少就去加载多少. 通常这也分为两种方式,一种是设置一个按钮,用户点击即加载.另一种是当用户滑动到底部时自动加载.今天我就和大家分享一下这个功能的实现. 首先,

ListView实现分页加载(一)制作Demo

一.什么是分页加载 在下面的文章中,我们来讲解LitView分页加载的实现.什么是分页加载呢?我们先看几张效果图吧,如下:                                               效果说明:我们向上滑动ListView的时候,当滑动的最底部, 便会出现正在加载的进度条,当加载完成后,会出现加载后的数据.如此反复,这其实就是ListView的分页加载功能.像这样的工能,实在是太常见了.那么它是怎么实现的呢? 实现原理很简单,本质上,其实就是一个自定义的ListV

分页加载

现在分页加载在apk中应用广泛 那么是怎么实现的呢 下面让我们举一个小例子来看一下 首先是我们的自定义的listview 在布局中引用 那么就看一下我们的布局文件 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="mat