Android实现简单的分页效果

本文实例为大家分享了Android分页效果的具体代码,供大家参考,具体内容如下

1.实现分页最主要的就是封装分页代码,然后在按钮里实现相关的操作

/**
 * 分页工具
 *
 * @Project App_Page
 * @Package com.android.dividepage
 * @author chenlin
 * @version 1.0
 * @Date 2012年6月2日
 * @Note TODO
 * @param <T>
 */
public class PageHelper<T> {

 private List<T> allData; // 所有数据
 private int perPage = 10; // 每页条目
 private int currentPage = 1;// 当前页
 private int pageNum = 1; // 页码
 private List<T> childData;// 子数据
 private int allNum;// 总共条目

 public PageHelper(List<T> datas, int perPage) {
 this.allData = datas;
 if (perPage > 0)
  this.perPage = perPage;
 // 如果数据大于10条
 if (allData != null && allData.size() > perPage) {
  childData = allData.subList(0, perPage - 1);
 }
 allNum = allData.size();
 // 如果总数能除断perPage,页数就是余数,否则+1
 pageNum = allNum % perPage == 0 ? (allNum / perPage) : (allNum / perPage + 1);
 }

 public int getCount() {
 return this.allNum;
 }

 public int getCurrentPage() {
 return this.currentPage;
 }

 public int getPageNum() {
 return this.pageNum;
 }

 public int getPerPage() {
 return this.perPage;
 }

 public void gotoPage(int n) { // 页面跳转
 currentPage = n > pageNum ? pageNum : (n < 1 ? 1 : n);
 }

 public boolean hasNextPage() {// 是否有下一页
 return currentPage < pageNum;
 }

 public boolean hasPrePage() {// 是否有前一页
 return currentPage > 1;
 }

 public void headPage() {// 第一页
 currentPage = 1;
 }

 public void lastPage() {// 最后一页
 currentPage = pageNum;
 }

 public void nextPage() {// 下一页
 currentPage = hasNextPage() ? currentPage + 1 : pageNum;
 }

 public void prePage() {// 前一页
 currentPage = hasPrePage() ? currentPage - 1 : 1;
 }

 public void setPerPage(int perPage) {// 设置上一页面
 this.perPage = perPage;
 }

 /**
 * 获得当前数据
 * @return
 */
 public List<T> currentList() {
 if (currentPage == 1) {
  childData = allData.subList(0, perPage);
 } else if (currentPage == pageNum) {
  childData = allData.subList(perPage * (pageNum - 1), allNum);
 } else {
  childData = allData.subList(perPage * (currentPage - 1), perPage * currentPage);
 }
 return childData;
 }

 public void setCurrentPage(int currentPage) {
 this.currentPage = currentPage;
 }

}

2、主页里我根据tab标签把按钮设置进去,然后在click里方法读取,最后根据tag标签就可判断是哪个按钮点击了

/**
 * 分页主页
 * @Project App_Page
 * @Package com.android.dividepage
 * @author chenlin
 * @version 1.0
 * @Date 2012年6月2日
 * @Note TODO
 */
public class MainActivity extends Activity implements OnClickListener {

 private ListView mListView;
 //分页按钮
 private Button mBtnPrePage, mBtnNextPage, mBtnPreItem, mBtnNextItem;
 //显示分页信息
 private TextView mTvPageNo;

 //数据实现
 private PageHelper<String> mPageDaoImpl;
 private DataAdapter mAdapter;
 private List<String> mDatas;

 //被选着的索引
 private int selectIndex = 0;

 private static final int PREPAGE = 0;
 private static final int NEXTPAGE = 1;
 private static final int PREITEM = 2;
 private static final int NEXTITEM = 3;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 initViews();
 initDatas();
 }

 private void initDatas() {
 //从资源文件里读数据
 mDatas = Arrays.asList(getResources().getStringArray(R.array.channellist));
 //每次读8条数据
 mPageDaoImpl = new PageHelper<String>(mDatas, 8);
 mAdapter = new DataAdapter(this, mPageDaoImpl.currentList());
 mListView.setAdapter(mAdapter);
 //设置当前页码与总页码
 mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
 }

 private void initViews() {
 mListView = (ListView) findViewById(R.id.page_list);
 mBtnPrePage = (Button) findViewById(R.id.pre_page);
 mBtnPrePage.setTag(PREPAGE);
 mBtnPrePage.setOnClickListener(this);
 mBtnNextPage = (Button) findViewById(R.id.next_page);
 mBtnNextPage.setTag(NEXTPAGE);
 mBtnNextPage.setOnClickListener(this);
 mBtnPreItem = (Button) findViewById(R.id.pre_item);
 mBtnPreItem.setTag(PREITEM);
 mBtnPreItem.setOnClickListener(this);
 mBtnNextItem = (Button) findViewById(R.id.next_item);
 mBtnNextItem.setTag(NEXTITEM);
 mBtnNextItem.setOnClickListener(this);

 mTvPageNo = (TextView) findViewById(R.id.pagenum);
 }

 @Override
 public void onClick(View v) {
 final int flag = (Integer) v.getTag();
 switch (flag) {
 case PREPAGE:// 首页
  headPage();
  break;
 case NEXTPAGE:// 尾页
  lastPage();
  break;
 case PREITEM:// 上一条
  prePage();
  break;
 case NEXTITEM:// 下一条
  nextPage();
  break;
 }
 }

 private void prePage() {
 if (selectIndex == 0) {
  if (mPageDaoImpl.getCurrentPage() >= 1) {
  mPageDaoImpl.prePage();
  }
  mAdapter.setData(mPageDaoImpl.currentList());
  mListView.setSelection(mAdapter.getCount() - 1);
  mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
 } else {
  return;
 }
 }

 private void nextPage() {
 if (mPageDaoImpl.getCurrentPage() <= mPageDaoImpl.getPageNum()) {
  mPageDaoImpl.nextPage();
 }
 mAdapter.setData(mPageDaoImpl.currentList());
 mListView.setSelection(0);
 mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
 }

 private void lastPage() {
 if (mPageDaoImpl.getCurrentPage() != mPageDaoImpl.getPageNum()) {
  mPageDaoImpl.lastPage();
 }
 mAdapter.setData(mPageDaoImpl.currentList());
 mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
 }

 private void headPage() {
 if (mPageDaoImpl.getCurrentPage() != 1) {
  mPageDaoImpl.headPage();
 }
 mAdapter.setData(mPageDaoImpl.currentList());
 mTvPageNo.setText(mPageDaoImpl.getCurrentPage() + " / " + mPageDaoImpl.getPageNum());
 }

}

3、适配器代码,太简单了,我就不说了

public class DataAdapter extends BaseAdapter {

 private Context mContext;
 private List<String> mDatas;

 public DataAdapter(Context context, List<String> datas) {
 this.mContext = context;
 this.mDatas = datas;
 }

 @Override
 public int getCount() {
 return mDatas == null ? 0 : mDatas.size();
 }

 @Override
 public Object getItem(int position) {
 return mDatas == null ? null : mDatas.get(position);
 }

 @Override
 public long getItemId(int position) {
 return position;
 }

 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
 ViewHolder mHolder;
 if (convertView == null) {
  convertView = LayoutInflater.from(mContext).inflate(R.layout.channel_item, parent, false);
  mHolder = new ViewHolder();
  mHolder.nameView = (TextView) convertView.findViewById(R.id.channel_name);
  convertView.setTag(mHolder);
 }
 mHolder = (ViewHolder) convertView.getTag();
 mHolder.nameView.setText(mDatas.get(position));
 return convertView;
 }

 static class ViewHolder {
 public TextView nameView;
 }

 public void setData(List<String> datas) {
 mDatas = datas;
 notifyDataSetChanged();
 }
}

4、代码下载:http://xiazai.jb51.net/201611/yuanma/AndroidAppPage(jb51.net).rar

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • android实现listview分页的方法

    本文实例讲述了android实现listview分页的方法.分享给大家供大家参考.具体分析如下: 最近做了下listview的分页,跟WEB上的分页是一个意思,需要那几个分页参数,不同的是sqlite中分页的查询语句,简便的方法需要用Limit,Offset关键字,前者是查询每页展示的记录数,后者是越过多少记录数,说得明白点就是忽略前面多少行记录之后,取多少行记录 我分页采用了一个重要的类Page,通过封装Page类,做为参数传递进来,返回出去也是个Page对象 import java.util

  • Android中实现多行、水平滚动的分页的Gridview实例源码

    功能要求: (1)比如每页显示2X2,总共2XN,每个item显示图片+文字(点击有链接). 如果单行水平滚动,可以用Horizontalscrollview实现. 如果是多行水平滚动,则结合Gridview(一般是垂直滚动的)和Horizontalscrollview实现. (2)水平滚动翻页,下面有显示当前页的icon. 1.实现自定义的HorizontalScrollView(HorizontalScrollView.java): 因为要翻页时需要传当前页给调用者,所以fling函数中自己

  • Android ListView分页功能实现方法

    通过本次小Demo我学到了: 1.ListView的小小的一个分页功能 2.加深了对自定义控件的理解 3.对ListView的优化 4.对BaseAdapter的使用 5.自定义Adapter 6.接口的回调 要实现下面的效果--当拖动ListView到底部的时候,显示一个ProgressBar和一个"正在加载..."的TextView.并且过两秒钟后,在下面加载出新的数据.项目的目录结构和程序要实现的效果如下:   首先是布局部分: 我为了实现此效果,首先在布局文件中新建了一个foo

  • Android之ListView分页加载数据功能实现代码

    什么是ListView分页加载数据功能呢?在现在的大数据时代,我们不可能把某些数据全部展示到界面,好比我们经常会看的QQ空间一样,当你看动态的时候,系统不可能会把所有好友的动态都展示在上面,你能看到的一般都是最新好友更新的动态,假如你要看非最新的好友动态,通常你都会手指向上滑动屏幕然后去查看,当界面下滑到一定数量的时候,就会看到一个"查看更多",然后突然停顿一下,系统会通过网络去给你刷新其他动态信息,这样的功能我们一般叫做数据下拉刷新功能,也就是我们的分页加载功能,具体的实现是怎样的呢

  • Android实现基于滑动的SQLite数据分页加载技术(附demo源码下载)

    本文实例讲述了Android实现基于滑动的SQLite数据分页加载技术.分享给大家供大家参考,具体如下: main.xml如下: <menu xmlns:android="http://schemas.android.com/apk/res/android" > <item android:id="@+id/action_settings" android:orderInCategory="100" android:showAs

  • Android实现ListView分页自动加载数据的方法

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

  • Android提高之SQLite分页读取实现方法

    一般来说,Android自身就包含了常用于嵌入式系统的SQLite,这样就免去了开发者自己移植安装的功夫.SQLite 支持多数SQL92标准,很多常用的SQL命令都能在SQLite上面使用,除此之外Android还提供了一系列自定义的方法去简化对SQLite数据库的操作.不过有跨平台需求的程序还是建议使用标准的SQL语句,毕竟这样容易在多个平台之间进行移植. 先来贴出本文程序运行的结果图: 本文实例程序主要讲解了SQLite的基本用法,如:创建数据库,使用SQL命令查询数据表.插入数据,关闭数

  • Android程序开发之Listview下拉刷新上拉(滑动分页)加载更多

    最近做的类似于微博的项目中,有个Android功能要使用到listview的向下拉刷新来刷新最新消息,向上拉刷新(滑动分页)来加载更多. 新浪微博就是使用这种方式的典型. 当用户从网络上读取微博的时候,如果一下子全部加载用户未读的微博这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了,其实这个分页可以做成客户端的分页,也可以做成服务器端的分页(点击加载时,从服务器对应的加载第N页就好了!!!).通过分

  • Android App中使用ViewPager实现滑动分页的要点解析

    以前如果要做 Tab 分页的话,必须要用一个很难用的 TabActivity,而且做出来的效果很差,弹性也很小 忘了从什么时候开始,Google release 了 ViewPager 这好东西取代了以前难用的 Gallery 元件,加上从 Honeycomb 导入的 Fragment 之后终于能够简单做出好看又好用的 Layout 了! 这里我们采用PagerTabStrip ,做出来的效果如下 特色就是使用简单,出来的效果则是目前显示的分页 Tab 的文字会自动置中,然后分别在左右显示上一个

  • Android滑动动态分页实现方法

    本文实例讲述了Android滑动动态分页实现方法.分享给大家供大家参考,具体如下: 实现 Android.widget.AbsListView.OnScrollListener 主要代码: private int lastItemIndex; @Override public void onScroll(AbsListView v, int firstVisibleItem,int visibleItemCount, int totalItemCount) { lastItemIndex = f

  • Android开发中滑动分页功能实例详解

    本文实例讲述了Android开发中滑动分页功能.分享给大家供大家参考,具体如下: android UI 往右滑动,滑动到最后一页就自动加载数据并显示 如图: Java代码: package cn.anycall.ju; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import andro

随机推荐