ListView实现分页功能【附Demo源码】

Android market里软件列表,每页显示10条记录,没有显示上一页,下一页的按钮,依靠手滑动动态加载数据,当向下滚动时,最下边显示 Loading… 。数据加载结束,Loading底栏消失。关于ListView的分段显示,有现成的库可用,比如 cwac-endless, 这个库不好之处,就是底部Loading的View无法定制。还有一个在google code上的androidpageablelistview 这个可以实现基本的分页,有手动操作显示上一页,下一页的按钮。查阅了很多资料,发现其实ListView自带一个实现分页加载的方法,用到 addFooterView/removeView 这两个函数“添加”或“去掉“ListView页脚。下面是一个研究ListView分页时做的一个Demo,比较简单,我把思路我源码和大家分享一下,希望对大家有所帮助。
效果图:ListViewLoading.png
实现思路如是:用onScroll方法实现”滑动“后处理检查是否还有新的记录,如果有,调用 addFooterView,添加记录到adapter, adapter调用 notifyDataSetChanged 更新数据;如果没有记录了, 把自定义的mFooterView去掉。这里没有重写onScrollStateChanged函数,那么在onScroll就需要一个外部变量 mFirstCell记录滑动位置。

代码如下:

 

    1. import android.app.ListActivity;  
    2. import android.os.Bundle;  
    3. import android.util.Log;  
    4. import android.view.Gravity;  
    5. import android.view.View;  
    6. import android.view.ViewGroup;  
    7. import android.widget.AbsListView;  
    8. import android.widget.BaseAdapter;  
    9. import android.widget.LinearLayout;  
    10. import android.widget.ListView;  
    11. import android.widget.ProgressBar;  
    12. import android.widget.TextView;  
    13. import android.widget.Toast;  
    14. import android.widget.AbsListView.OnScrollListener;  
    15. import android.widget.LinearLayout.LayoutParams;  
    16. /** 
    17. * 
    18. * @author huangbq 
    19. * 
    20. */  
    21. public class MainActivity extends ListActivity implements OnScrollListener {  
    22.   
    23. private static final String TAG = "MainActivity";  
    24. private listViewAdapter adapter = new listViewAdapter();  
    25. ListView listView ;  
    26. private int lastItem = 0;  
    27. LinearLayout loadingLayout;  
    28. /** 
    29.   * 设置布局显示属性 
    30.   */  
    31.     private LayoutParams mLayoutParams =new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT);  
    32.     /** 
    33.   * 设置布局显示目标最大化属性 
    34.   */  
    35.     private LayoutParams FFlayoutParams =new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,LinearLayout.LayoutParams.FILL_PARENT);  
    36.      
    37. private ProgressBar progressBar;  
    38. @Override  
    39. protected void onCreate(Bundle savedInstanceState) {  
    40.   super.onCreate(savedInstanceState);  
    41.   Log.i(TAG, "onCreate(Bundle savedInstanceState)>>>>>>>>>>>>>>>" );  
    42.      //线性布局  
    43.   LinearLayout layout = new LinearLayout(this);  
    44.     //设置布局 水平方向  
    45.   layout.setOrientation(LinearLayout.HORIZONTAL);  
    46.    //进度条  
    47.   progressBar = new ProgressBar(this);  
    48.    //进度条显示位置  
    49.   progressBar.setPadding(00150);  
    50.   //把进度条加入到layout中  
    51.   layout.addView(progressBar, mLayoutParams);  
    52.   //文本内容  
    53.   TextView textView = new TextView(this);  
    54.   textView.setText("加载中...");  
    55.   textView.setGravity(Gravity.CENTER_VERTICAL);  
    56.   //把文本加入到layout中  
    57.   layout.addView(textView, FFlayoutParams);  
    58.   //设置layout的重力方向,即对齐方式是  
    59.   layout.setGravity(Gravity.CENTER);  
    60.     
    61.   //设置ListView的页脚layout  
    62.   loadingLayout = new LinearLayout(this);  
    63.   loadingLayout.addView(layout, mLayoutParams);  
    64.   loadingLayout.setGravity(Gravity.CENTER);  
    65.     
    66.   //得到一个ListView用来显示条目  
    67.   listView = getListView();  
    68.   //添加到页脚显示  
    69.   listView.addFooterView(loadingLayout);  
    70.   //给ListView添加适配器  
    71.   setListAdapter(adapter);  
    72.   //给ListView注册滚动监听  
    73.   listView.setOnScrollListener(this);  
    74. }  
    75. @Override  
    76. public void onScroll(AbsListView v, int firstVisibleItem,  
    77.    int visibleItemCount, int totalItemCount) {  
    78.   Log.i(TAG , "Scroll>>>first: " + firstVisibleItem + ", visible: " + visibleItemCount + ", total: " + totalItemCount);  
    79.   lastItem = firstVisibleItem + visibleItemCount - 1;  
    80.   Log.i(TAG , "Scroll>>>lastItem:" + lastItem);  
    81.   //显示50条ListItem,即0-49,因为onScroll是在“滑动”执行过之后才触发,所以用adapter.count<=41作条件  
    82.   if (adapter.count<=41) {  
    83.    if (firstVisibleItem+visibleItemCount==totalItemCount) {  
    84.     adapter.count += 10;  
    85.     adapter.notifyDataSetChanged();  
    86.     listView.setSelection(lastItem);  
    87.     int currentPage=adapter.count/10;  
    88.     Toast.makeText(getApplicationContext(), "第"+currentPage+"页", Toast.LENGTH_LONG).show();  
    89.    }  
    90.   }  
    91.   else {  
    92.     listView.removeFooterView(loadingLayout);  
    93.   }  
    94.     
    95.     
    96. }  
    97. @Override  
    98. public void onScrollStateChanged(AbsListView v, int state) {  
    99.   if (lastItem == adapter.count && state == OnScrollListener.SCROLL_STATE_IDLE) {  
    100.    Log.i(TAG,"ScrollStateChanged>>>state:"+state+"lastItem:" + lastItem);  
    101.    //显示50条ListItem,即0-49,因为onScrollStateChanged是在“拖动滑动”执行过之后才触发,所以用adapter.count<=41作条件  
    102.    if (adapter.count<=41) {  
    103.     adapter.count += 10;  
    104.     adapter.notifyDataSetChanged();  
    105.    }  
    106.   
    107.   }  
    108. }  
    109.   /** 
    110.    * 要用用于生成显示数据 
    111.    * @author huangbq 
    112.    * 
    113.    */  
    114. class listViewAdapter extends BaseAdapter {  
    115.   int count = 10;  
    116.   public int getCount() {  
    117.    Log.i(TAG, "getCount>>>count:" + count);  
    118.    return count;  
    119.   }  
    120.   public Object getItem(int pos) {  
    121.    Log.i(TAG, "getItem>>>pos:" + pos);  
    122.    return pos;  
    123.   }  
    124.   public long getItemId(int pos) {  
    125.    Log.i(TAG, "getItemId>>>ItemId:" + pos);  
    126.    return pos;  
    127.   }  
    128.   public View getView(int pos, View v, ViewGroup p) {  
    129.    Log.i(TAG, "getView>>>pos:" + pos);  
    130.    TextView view;  
    131.    if (v==null) {  
    132.     view = new TextView(MainActivity.this);  
    133.    }  
    134.    else {  
    135.     view=(TextView)v;  
    136.    }  
    137.    view.setText("ListItem " + pos);  
    138.    view.setTextSize(20f);  
    139.    view.setGravity(Gravity.CENTER);  
    140.    view.setHeight(60);  
    141.    return view;  
    142.   }  
    143. }  
    144. }  
posted @ 2014-03-10 10:18  huidaoli  阅读(434)  评论(0编辑  收藏  举报