Android之分页加载数据
基本的原理和我的上一篇随笔“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之分页加载数据的更多相关文章
- Android GridView 分页加载数据
android UI 往右滑动,滑动到最后一页就自动加载数据并显示 如图: package cn.anycall.ju; import java.util.ArrayList; import java ...
- android ListView 分页加载数据
1.mainActivity <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" ...
- java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单
一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...
- Android中ListView分页加载数据
public class MainActivity extends Activity { private ListView listView=null; //listview的数据填充器 privat ...
- 【Android进阶】Listview分页加载数据的实现
Listview分页加载数据的实现 public class MainActivity extends Activity { protected static final int SUCCESS_GE ...
- android 网络异步加载数据进度条
ProgressDialog progressDialog = null; public static final int MESSAGETYPE = 0; private void execute( ...
- jQuery 滚动条 滚动到底部(下拉到底部) 加载数据(触发事件、处理逻辑)、分页加载数据
1.针对浏览器整个窗口滚动 主要代码: <script type="text/javascript"> ; function GetProductListPageFun ...
- Android ListView分页加载时图片显示问题
场景:Android ListView需要分页加载,每个item中会有图片,图片又是从网络下载的. 问题:在滑动加载下一页时,上一页的图片明明已经下载完成了,但是无法显示出来. Bug重现: 1,加载 ...
- listView 分页加载数据
Android应用 开发中,采用ListView组件来展示数据是很常用的功能,当一个应用要展现很多的数据时,一般情况下都不会把所有的数据一次就展示出来,而是通过分页 的形式来展示数据,个人觉得这样会有 ...
随机推荐
- Linux 下dns的搭建
1.软件安装: redhat默认使用bind作为安装软件 使用yum安装 yum install -y bind bind-chroot bind-utils bind提供主程序 bind-chroo ...
- mdadm设定RAID磁盘阵列,且当分区故障后如何重建
首先,fdisk建立不同分区,且设为fd格式 其次, mdadm -C md0 -a yes -l -n /dev/sda1 /dev/sdb1 /dev/sdc1 /dev/sdd1 /dev/sd ...
- js给数组去重写法
数组为 var list =['A','B','A']; 法一:常规做法,新建list,给list添加元素,添加前判断是否包含 var removeRepeatItem = function(list ...
- codevs 1164 统计数字
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题目描述 Description [问题描述]某次科研调查时得到了n个自然数,每个数均不超过150000000 ...
- BZOJ 1004 【HNOI2008】 Cards
题目链接:Cards 听说这道题是染色问题的入门题,于是就去学了一下\(Bunside\)引理和\(P\acute{o}lya\)定理(其实还是没有懂),回来写这道题. 由于题目中保证"任意 ...
- python2.7高级编程 笔记一(Python中的with语句与上下文管理器学习总结)
0.关于上下文管理器上下文管理器是可以在with语句中使用,拥有__enter__和__exit__方法的对象. with manager as var: do_something(var) 相当于以 ...
- Python--基础知识
- angular
- css中,设置百分比后,让百分比的宽度包括padding和border来计算
*{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}
- weui tabbar 切换
Html: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <met ...