ListView实现分页功能

导读:Android market里软件列表,每页显示10条记录,没有显示上一页,下一页的按钮,依靠手滑动动态加载数据,当向下滚动时,最下边显示 Loading… 。数据加载结束,Loading底栏消失。

 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记录滑动位置。

代码如下:

001 import android.app.ListActivity;
002 import android.os.Bundle;
003 import android.util.Log;
004 import android.view.Gravity;
005 import android.view.View;
006 import android.view.ViewGroup;
007 import android.widget.AbsListView;
008 import android.widget.BaseAdapter;
009 import android.widget.LinearLayout;
010 import android.widget.ListView;
011 import android.widget.ProgressBar;
012 import android.widget.TextView;
013 import android.widget.Toast;
014 import android.widget.AbsListView.OnScrollListener;
015 import android.widget.LinearLayout.LayoutParams;
016 /**
017 *
018 * @author huangbq
019 *
020 */
021 public class MainActivity extends ListActivity implementsOnScrollListener {
022  
023 private static final String TAG = "MainActivity";
024 private listViewAdapter adapter = new listViewAdapter();
025 ListView listView ;
026 private int lastItem = 0;
027 LinearLayout loadingLayout;
028 /**
029   * 设置布局显示属性
030   */
031     private LayoutParams mLayoutParams =newLinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT);
032     /**
033   * 设置布局显示目标最大化属性
034   */
035     private LayoutParams FFlayoutParams =newLinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,LinearLayout.LayoutParams.FILL_PARENT);
036     
037 private ProgressBar progressBar;
038 @Override
039 protected void onCreate(Bundle savedInstanceState) {
040   super.onCreate(savedInstanceState);
041   Log.i(TAG, "onCreate(Bundle savedInstanceState)>>>>>>>>>>>>>>>" );
042      //线性布局
043   LinearLayout layout = new LinearLayout(this);
044     //设置布局 水平方向
045   layout.setOrientation(LinearLayout.HORIZONTAL);
046    //进度条
047   progressBar = new ProgressBar(this);
048    //进度条显示位置
049   progressBar.setPadding(00150);
050   //把进度条加入到layout中
051   layout.addView(progressBar, mLayoutParams);
052   //文本内容
053   TextView textView = new TextView(this);
054   textView.setText("加载中...");
055   textView.setGravity(Gravity.CENTER_VERTICAL);
056   //把文本加入到layout中
057   layout.addView(textView, FFlayoutParams);
058   //设置layout的重力方向,即对齐方式是
059   layout.setGravity(Gravity.CENTER);
060    
061   //设置ListView的页脚layout
062   loadingLayout = new LinearLayout(this);
063   loadingLayout.addView(layout, mLayoutParams);
064   loadingLayout.setGravity(Gravity.CENTER);
065    
066   //得到一个ListView用来显示条目
067   listView = getListView();
068   //添加到页脚显示
069   listView.addFooterView(loadingLayout);
070   //给ListView添加适配器
071   setListAdapter(adapter);
072   //给ListView注册滚动监听
073   listView.setOnScrollListener(this);
074 }
075 @Override
076 public void onScroll(AbsListView v, int firstVisibleItem,
077    int visibleItemCount, int totalItemCount) {
078   Log.i(TAG , "Scroll>>>first: " + firstVisibleItem + ", visible: " + visibleItemCount + ", total: " + totalItemCount);
079   lastItem = firstVisibleItem + visibleItemCount - 1;
080   Log.i(TAG , "Scroll>>>lastItem:" + lastItem);
081   //显示50条ListItem,即0-49,因为onScroll是在“滑动”执行过之后才触发,所以用adapter.count<=41作条件
082   if (adapter.count<=41) {
083    if (firstVisibleItem+visibleItemCount==totalItemCount) {
084     adapter.count += 10;
085     adapter.notifyDataSetChanged();
086     listView.setSelection(lastItem);
087     int currentPage=adapter.count/10;
088     Toast.makeText(getApplicationContext(), "第"+currentPage+"页", Toast.LENGTH_LONG).show();
089    }
090   }
091   else {
092     listView.removeFooterView(loadingLayout);
093   }
094    
095    
096 }
097 @Override
098 public void onScrollStateChanged(AbsListView v, int state) {
099   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 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
WPF 中的 DataGrid 和 ListView 都没有内置的分页控件,但可以通过一些方法来实现分页功能。 一种实现方式是使用 CollectionView,它是用于对集合进行排序、过滤和分组的类。可以使用 CollectionViewSource 创建 CollectionView,并在 XAML 中绑定到分页控件中。 以下是一个示例,其中使用 CollectionViewSource 来创建 CollectionView,并将其绑定到 ListView 控件中: ```xml <Grid> <Grid.Resources> <CollectionViewSource x:Key="cvs" Source="{Binding Items}" PageSize="10"/> </Grid.Resources> <ListView ItemsSource="{Binding Source={StaticResource cvs}}" /> <StackPanel Orientation="Horizontal" HorizontalAlignment="Center"> <Button Content="Prev" Command="{Binding Source={StaticResource cvs}, Path=PageUpCommand}" /> <TextBlock Text="{Binding Source={StaticResource cvs}, Path=PageIndex}" /> <Button Content="Next" Command="{Binding Source={StaticResource cvs}, Path=PageDownCommand}" /> </StackPanel> </Grid> ``` 在上面的示例中,CollectionViewSource 用于创建 CollectionView,并使用 PageSize 属性来指定每页的项数。ListView 控件绑定到 CollectionViewSource 中的 CollectionView。 同时,使用按钮来切换分页,每个按钮都绑定到 CollectionViewSource 中的 PageUpCommand 和 PageDownCommand 命令,以便在前一页和后一页之间切换。 还有其他的实现方式,例如手动分页和使用第三方分页控件等等。具体实现方式可以根据项目需求来选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值