基本的原理和我的上一篇随笔“Android之下拉刷新ListView”差不多,代码里面有注释,这里就不废话了,直接上代码。

自定义的分页显示ListView——PagedListView.java代码如下:

 public class PagedListView extends ListView implements OnScrollListener {
private View footer; // 底部布局
private LayoutInflater inflater;
private int totalItemCount; // 总的Item的数量
private int lastVisibleItemIndex; // 最后一个可见的Item的索引
private boolean isLoading; // 是否正在加载
private ListViewLoadListener listener; // 加载更多数据的回掉接口 public PagedListView(Context context) {
this(context, null);
} public PagedListView(Context context, AttributeSet attrs) {
this(context, attrs, 0);
} public PagedListView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
initView(context);
} // 加载底部布局到ListView中
private void initView(Context context) {
inflater = LayoutInflater.from(context);
footer = inflater.inflate(R.layout.sideworks_layout_footer, null);
footer.findViewById(R.id.control_layout_footer).setVisibility(View.GONE);
this.addFooterView(footer);
this.setOnScrollListener(this);
} @Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
this.lastVisibleItemIndex = firstVisibleItem + visibleItemCount;
this.totalItemCount = totalItemCount;
} @Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
if (totalItemCount == lastVisibleItemIndex && scrollState == SCROLL_STATE_IDLE) {
if (!isLoading) {
isLoading = true;
footer.findViewById(R.id.control_layout_footer).setVisibility(View.VISIBLE);
listener.loadData(); // 调用接口中的回调方法进行数据更新
}
}
} // 加载更多数据的回掉接口
public interface ListViewLoadListener {
public void loadData();
} public void setListViewLoadInterface(ListViewLoadListener listener) {
this.listener = listener;
} // 数据加载完成之后,隐藏footer布局
public void onLoadComplete() {
isLoading = false;
footer.findViewById(R.id.control_layout_footer).setVisibility(View.GONE);
}
}

底部布局sideworks_layout_footer.xml的代码如下:

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content" > <!-- 这里必须要套一层LinearLayout,不然在代码中设置Visibility为Gone时底部总是会有一部分空白区域 -->
<LinearLayout
android:id="@+id/control_layout_footer"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#e7e7e7"
android:gravity="center"
android:orientation="horizontal"
android:paddingBottom="10.0dip"
android:paddingTop="10.0dip" > <ProgressBar
style="?android:attr/progressBarStyleSmall"
android:layout_width="wrap_content"
android:layout_height="wrap_content" /> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="15.0dip"
android:text="@string/str_footer_tip"
android:textColor="#777777" />
</LinearLayout> </LinearLayout>

主页面布局activity_main.xml代码如下:

 <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" > <com.view.PagedListView
android:id="@+id/control_main_listview"
android:layout_width="match_parent"
android:layout_height="match_parent" /> </RelativeLayout>

主界面MainActivity.java代码如下:

 public class MainActivity extends Activity implements ListViewLoadListener {
private PagedListView listView;
private ArrayAdapter<String> listAdapter;
private List<String> listData; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
} private void initView() {
listView = (PagedListView) findViewById(R.id.control_main_listview);
listView.setListViewLoadInterface(this);
listData = new ArrayList<String>();
for (int i = 0; i < 10; i++) {
listData.add("This is an initial data.");
}
listAdapter = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_expandable_list_item_1, listData);
listView.setAdapter(listAdapter);
} @Override
public void loadData() {
new Handler().postDelayed(new Runnable() {
public void run() {
// 增加两条数据并通知ListView进行数据的更新
for (int i = 0; i < 2; i++) {
listData.add("This is a new data.");
}
listAdapter.notifyDataSetChanged();
listView.onLoadComplete();
}
}, 2000);
}
}

Android之分页加载数据的更多相关文章

  1. Android GridView 分页加载数据

    android UI 往右滑动,滑动到最后一页就自动加载数据并显示 如图: package cn.anycall.ju; import java.util.ArrayList; import java ...

  2. android ListView 分页加载数据

    1.mainActivity <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" ...

  3. java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单

    一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...

  4. Android中ListView分页加载数据

    public class MainActivity extends Activity { private ListView listView=null; //listview的数据填充器 privat ...

  5. 【Android进阶】Listview分页加载数据的实现

    Listview分页加载数据的实现 public class MainActivity extends Activity { protected static final int SUCCESS_GE ...

  6. android 网络异步加载数据进度条

    ProgressDialog progressDialog = null; public static final int MESSAGETYPE = 0; private void execute( ...

  7. jQuery 滚动条 滚动到底部(下拉到底部) 加载数据(触发事件、处理逻辑)、分页加载数据

    1.针对浏览器整个窗口滚动 主要代码: <script type="text/javascript"> ; function GetProductListPageFun ...

  8. Android ListView分页加载时图片显示问题

    场景:Android ListView需要分页加载,每个item中会有图片,图片又是从网络下载的. 问题:在滑动加载下一页时,上一页的图片明明已经下载完成了,但是无法显示出来. Bug重现: 1,加载 ...

  9. listView 分页加载数据

    Android应用 开发中,采用ListView组件来展示数据是很常用的功能,当一个应用要展现很多的数据时,一般情况下都不会把所有的数据一次就展示出来,而是通过分页 的形式来展示数据,个人觉得这样会有 ...

随机推荐

  1. HTML中使图片居中显示

    注:imageId为图片id<style type="text/css"> #imageId{ display:block; position:relative; ma ...

  2. (转)socket Aio demo

    原文地址: https://my.oschina.net/tangcoffee/blog/305656 参考文档: http://my.oschina.net/u/862897/blog/164425 ...

  3. HOLOLENS 扫描特效 及得出扫描结果(SurfacePlane)

    HOLOLENS 扫描特效 及得出扫描结果(SurfacePlane) 要求只扫出地板和墙, 由于地板和墙面积较大 扫描结果 HOLOTOOLKIT老版本点在参数调节PlaneFinding.Find ...

  4. Integrating SharePoint 2013 with ADFS and Shibboleth

    Time again to attempt to implement that exciting technology, Federation Services (Web Single Sign On ...

  5. 微信小程序-多级联动

    微信小程序中的多级联动 这里用到的案例是城市选择器 先上代码: .wxml <view class="{{boxHide}}"> <view>{{nian} ...

  6. 网络切片在5G中的应用

    SDNLAB君 • 16-11-25 •1509 人围观 5G和网络切片 当5G被广泛提及的时候,网络切片是其中讨论最多的技术.像KT.SK Telecom.China Mobile.DT.KDDI. ...

  7. C#使用zxing,zbar,thoughtworkQRcode解析二维码,附源代码

    最近做项目需要解析二维码图片,找了一大圈,发现没有人去整理下开源的几个库案例,花了点时间 做了zxing,zbar和thoughtworkqrcode解析二维码案例,希望大家有帮助. zxing是谷歌 ...

  8. python网络编程-socket编程

     一.服务端和客户端 BS架构 (腾讯通软件:server+client) CS架构 (web网站) C/S架构与socket的关系: 我们学习socket就是为了完成C/S架构的开发 二.OSI七层 ...

  9. express不是内部或外部命令

    网上找了一下原因,是因为express在4.0以后把命令工具单独分出来了,所以安装完express后,还得再安装express-generator: 如果不是采用的全局安装,则需要把 "安装 ...

  10. 递推 hdu 3411

    http://blog.csdn.net/wust_xhj/article/details/47779539 怎么推可以看这里 f[0]=0 f[1]=1 [0,1]* | 0  q  |(n-1)= ...