Android ListView分页,动态添加数据
1.ListView分页的实现,重点在于实现OnScrollListener接口,判断滑动到最后一项时,是否还有数据可以加载,
我们可以利用listView.addFootView(View v)方法进行提示
自定义一个ListView(这里本来想进行一些自定已修改的。。。实际代码并没有做)CornerListView
package com.example.testlistview; import android.widget.AbsListView;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.ListView; public class CornerListView extends ListView{ public CornerListView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
// TODO Auto-generated constructor stub
} public CornerListView(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
} public CornerListView(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
}
包含ListView的配置文件 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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.testlistview.MainActivity" > <com.example.testlistview.CornerListView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_margin="10dip"
android:id="@+id/list"
>
</com.example.testlistview.CornerListView> </RelativeLayout>
ListView每一项的Item配置文件 listview_item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <TextView
android:id="@+id/tvTitle"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="1"
android:gravity="center_horizontal"
></TextView>
</LinearLayout>
有更多数据时的配置文件more.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TextView
android:id="@+id/tv_msg"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="更多"
/>
<ProgressBar
android:id="@+id/loading"
style="@android:style/Widget.ProgressBar.Large"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:visibility="gone"
/>
</RelativeLayout>
CorernerListView对应的Adapter适配器 CornerAdapter.java
package com.example.testlistview; import java.util.List; import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView; public class CornerAdapter extends BaseAdapter{ LayoutInflater inflater;
public List<String> list;
private Context context; public CornerAdapter(List<String> list, Context context) {
this.list = list;
this.context = context;
} @Override
public int getCount() {
return list.size();
} @Override
public Object getItem(int position) {
return list.get(position);
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder;
if(convertView == null)
{
viewHolder = new ViewHolder();
convertView = LayoutInflater.from(context).inflate(R.layout.listview_item, null, false);
TextView tv1= (TextView) convertView.findViewById(R.id.tvTitle);
viewHolder.tv = tv1;
convertView.setTag(viewHolder);
}
else
{
viewHolder = (ViewHolder) convertView.getTag();
}
viewHolder.tv.setText(list.get(position));
return convertView;
} class ViewHolder{
public TextView tv;
}
}
主Activity代码:
package com.example.testlistview; import java.util.ArrayList;
import java.util.List; import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.TextView; public class MainActivity extends Activity implements OnScrollListener{ private int pageIndex = 1;
private int pageSize = 2;
private int pageCount = 2;//初始设置页数为2,因为刚开始不知道总页数
private CornerListView listView;
private CornerAdapter adapter;
private View footer,tvMsg,loading;
private boolean is_divPage = false;//是否分页
private List<String> list = new ArrayList<String>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = (CornerListView) findViewById(R.id.list);
listView.setOnScrollListener(this);
footer = View.inflate(this, R.layout.more, null);
tvMsg = footer.findViewById(R.id.tv_msg);
loading = footer.findViewById(R.id.loading);
listView.addFooterView(footer);//添加footerview
Thread thread = new Thread(runnable);//第一次访问服务器接口,返回第一页信息,并确定总页数信息
thread.start();
} //异步访问网络加载数据之类的。。
Runnable runnable = new Runnable() { @Override
public void run() {
//传递pageIndex,pageSize,URL等参数访问网络获取数据,这里省略。。。
//doSomething
String strJson = "";//假定strJson就是服务器返回的这一页Json数据
//假设这里返回总页数为5
pageCount = 5;
Message msg = new Message();
msg.obj = strJson;
handler.sendMessage(msg);//将消息返回给UI }
}; //处理返回的消息,设置ListView
Handler handler = new Handler(){ @Override
public void handleMessage(Message msg) {
String strJson = msg.obj.toString();
//各种转换组合数据,这里我们就不做了,模拟一下数据
for(int i=0;i<pageSize; ++i)
{
if(adapter != null && adapter.list != null)//从获取第二页开始,直接修改适配器的list
{
adapter.list.add(i+"");
}
else//第一次适配器还没有构造
{
list.add(i+"");
}
}
if(pageIndex == 1)//第一次,设置适配器
{
adapter = new CornerAdapter(list, MainActivity.this);
listView.setAdapter(adapter);
//判断一下是否显示更多按钮
if(pageIndex == pageCount)
{
listView.removeFooterView(footer);
}
else if(pageIndex < pageCount)
{
//设置tvmsg显示,加载动画不显示
tvMsg.setVisibility(View.VISIBLE);
loading.setVisibility(View.GONE);
}
}
else
{
//直接调用方法更新数据
adapter.notifyDataSetChanged();
if(pageIndex == pageCount)
{
listView.removeFooterView(footer);
}
else if(pageIndex < pageCount)
{
//设置tvmsg显示,加载动画不显示
tvMsg.setVisibility(View.VISIBLE);
loading.setVisibility(View.GONE);
}
} } }; @Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
//需要分页,触摸停止,当前确实还有分页数据
if(is_divPage && scrollState == OnScrollListener.SCROLL_STATE_IDLE && pageIndex < pageCount)
{
pageIndex += 1;//设置请求当前页码加1
Thread thread = new Thread(runnable);
thread.start();
}
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
//现在 Bug初始情况下向下滑动也能翻页
int lastVisibleItem = firstVisibleItem + visibleItemCount;//当前滑动到最后一项
if(lastVisibleItem == totalItemCount && totalItemCount > 0)
{
is_divPage = true;
}
}
}
Android ListView分页,动态添加数据的更多相关文章
- android ListView 分页加载数据
1.mainActivity <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" ...
- Android之ListView动态添加数据(SQLiteOpenHelper类添加数据)
一.SQLiteOpenHelper类: 这次我们通过sqlite来动态添加数据,接下来我们创建一个openHelper.java,在前面sqlite博客中我们已经详细的讲了SQLite的创建及使用等 ...
- 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 --ListView分页
参考博客:Android ListView分页加载(服务端+android端)Demo 监听OnScrollListener事件 class OnListScrollListener implemen ...
- Android ListView分页载入(服务端+android端)Demo
Android ListView分页载入功能 在实际开发中经经常使用到,是每一个开发人员必须掌握的内容,本Demo给出了服务端+Android端的两者的代码,并成功通过了測试. 服务端使用MyEcli ...
- 关于devexpress报表XtraReport,动态修改报表样式(.repx格式),动态添加数据并使用的理解
一.基本概念: XtraReports 中的每个报表都由 XtraRepot 类的一个实例表示,或者由该类的子类来表示(这种情况更常见). 因此,每个报表都作为带区的容器使用,而每个带区中都包含报表控 ...
- js表单动态添加数据并提交
情景1:已经存在form对象了,动态为form增加对象并提交 function formAppendSubmit(){ var myform=$('#newArticleForm'); //得到for ...
- 【javascript 动态添加数据到 HTML 页面】
今天简单的学习了一下有关对象字面量的定义和 javascript 如何取出对象字面量的值的知识,javascript 动态添加数据到 HTML 页面的问题. [学习目标]有如下的一组数据通过 Ajax ...
- 第27讲 UI组件之 ScrollView与底部动态添加数据
第27讲 UI组件之 ScrollView与底部动态添加数据 1. ScrollView(滚动视图) ScrollView(滚动视图)是实现滚动的一个控件,只需要将需要滚动的控件添加到ScrollVi ...
随机推荐
- 条款14:在资源管理类中心copying行为(Think carefully about copying behavior in resource-manage classes)
NOTE: 1.复制RAII 对象必须一并赋值它所管理的资源,所以资源的copying行为决定RAII对象的copying行为. 2.普遍而常见的RAII class copying 行为是: 抑制c ...
- 开发语言之---Python
Python,如果你想进军AI,或是不想被自动化运维淘汰,Python是一门必须课. 在未来的大学课堂上,也许也会将Python加入必修中,就像Java一样. Python之“Hello World” ...
- 又见GCD (已知最大公约数和其中一个数求另一个数)
#include<cstdio> int f1(int a,int b) //最大公约数 { ) return b; else return f1(b,a%b); } int f2(int ...
- 算法导论 第三章 and 第四章
第三章 渐进的基本O().... 常用函数 % 和 // 转换 斯特林近似公式 斐波那契数 第四章 分治策略:分解(递归)--解决(递归触底)--合并 求解递归式的3种方法: 1:代入法(替代法): ...
- 分享一段代码,关于List
@SuppressWarnings("unchecked") public List<LogisticsOrderType> getAllLogisticsOrderT ...
- Android开发——查询/卸载手机里的应用、应用图标创建
1. 获取手机里的所有已安装的应用 以前写过一个SoftProviderUtil工具类,拿出来分享一个.通过PackageManager,不仅可以获取PackageName,判断此进程是否为系统应用, ...
- centos挂载本地镜像作为yum源
1.安装Centos后默认的Yum源如下 ll /etc/yum.repos.d/ [root@localhost ~]# ll /etc/yum.repos.d/ total 32 -rw-r- ...
- ubuntu安装远程桌面连接工具
1. 安装xrdp sudo apt-get -y install xrdp 2.安装vnc4server sudo apt-get install vnc4server 3.安装xubunt ...
- JavaScript中变量、作用域和内存问题(JavaScript高级程序设计第4章)
一.变量 (1)ECMAScript变量肯能包含两种不同的数据类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段,引用类型值指那些可能由多个值构成的对象. (2)基本数据类型是按值访问,可 ...
- python019 Python3 File(文件) 方法
file 对象使用 open 函数来创建,下表列出了 file 对象常用的函数: 序号 方法及描述 1 file.close() 关闭文件.关闭后文件不能再进行读写操作. 2 file.flush() ...