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 ...
随机推荐
- 关键css
参考: 掘金-JS和CSS的位置对资源加载顺序的影响 起舞-什么是关键CSS 有兴趣也可以看看这里一篇关于页面加载的文章.以上掘金那篇文章说css的加载不会影响其他资源的下载,但是我测试了一下,发现是 ...
- linux 服务器 php vue项目部署流程总结
服务器配置 购买阿里云服务器 (选择ubuntu 16系统 / 内存2G以上) 安全策略, 入规则: 添加端口 20,21,22, 80, 443, 3306, 8080, 安装宝塔 wget -O ...
- php 后端规范
后端框架地址: git@gitee.com:xielisen/xcore.git 框架使用规范,内部沟通 Controller命名规范 1, 首字母大写,其余小写 2, 对应数据库名称. 不要下划线 ...
- 大数据学习——hdfs客户端操作
package cn.itcast.hdfs; import org.apache.commons.io.IOUtils; import org.apache.hadoop.conf.Configur ...
- Computer (树形DP)
A school bought the first computer some time ago(so this computer's id is 1). During the recent year ...
- Java实战及解析 — Maven快速入门
五分钟快速入门 mvn --version mvn archetype:generate -DgroupId=com.mycompany.app -DartifactId=my-app -Darche ...
- Codeforces Round #386 (Div. 2) A+B+C+D!
A. Compote 水题(数据范围小都是水题),按照比例找最小的就行了,3min水过. int main() { int a,b,c; while(~scanf("%d%d%d" ...
- Oracle臨時表空間過大問題解決
查詢資料庫伺服器時,發現資料庫伺服器磁片使用空間達到了98%,分析總共的資料檔案也不可能達到如此大,經過查詢發現原來臨時表空間的使用方式達到了 32G,導致磁碟空間使用緊張.搜索了相應的文檔與資料後, ...
- BZOJ1693: [Usaco2007 Demo]Asteroids
n<=500 *n的格子,给m<=10000个格子有人,一炮可以清掉一行或一列的人(莫名的爽!)求最少几炮干掉所有人. 经典二分图模型!行成点,列成点,一个点就连接一行一列,表示这一行或这 ...
- 内存管理(——高质量程序设计语言C/C++第16章)
内存的分配方式: 1.静态存储区分配:全局变量,static变量等,在程序编译时已经分配了存储内存,在程序运行的整个期间一直存在 2.程序的堆栈上:程序的局部变量,包括程序的形参等,只存在于程序的运行 ...