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分页,动态添加数据的更多相关文章

  1. android ListView 分页加载数据

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

  2. Android之ListView动态添加数据(SQLiteOpenHelper类添加数据)

    一.SQLiteOpenHelper类: 这次我们通过sqlite来动态添加数据,接下来我们创建一个openHelper.java,在前面sqlite博客中我们已经详细的讲了SQLite的创建及使用等 ...

  3. Android中ListView分页加载数据

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

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

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

  5. Android --ListView分页

    参考博客:Android ListView分页加载(服务端+android端)Demo 监听OnScrollListener事件 class OnListScrollListener implemen ...

  6. Android ListView分页载入(服务端+android端)Demo

    Android ListView分页载入功能 在实际开发中经经常使用到,是每一个开发人员必须掌握的内容,本Demo给出了服务端+Android端的两者的代码,并成功通过了測试. 服务端使用MyEcli ...

  7. 关于devexpress报表XtraReport,动态修改报表样式(.repx格式),动态添加数据并使用的理解

    一.基本概念: XtraReports 中的每个报表都由 XtraRepot 类的一个实例表示,或者由该类的子类来表示(这种情况更常见). 因此,每个报表都作为带区的容器使用,而每个带区中都包含报表控 ...

  8. js表单动态添加数据并提交

    情景1:已经存在form对象了,动态为form增加对象并提交 function formAppendSubmit(){ var myform=$('#newArticleForm'); //得到for ...

  9. 【javascript 动态添加数据到 HTML 页面】

    今天简单的学习了一下有关对象字面量的定义和 javascript 如何取出对象字面量的值的知识,javascript 动态添加数据到 HTML 页面的问题. [学习目标]有如下的一组数据通过 Ajax ...

  10. 第27讲 UI组件之 ScrollView与底部动态添加数据

    第27讲 UI组件之 ScrollView与底部动态添加数据 1. ScrollView(滚动视图) ScrollView(滚动视图)是实现滚动的一个控件,只需要将需要滚动的控件添加到ScrollVi ...

随机推荐

  1. docker-compose文件语法解析(v3.x)

    文件配置 compose文件是一个定义服务(service).网络(network)和卷(volume)的YAML文件 .Compose 文件的默认路径是 ./docker-compose.yml 提 ...

  2. Python_编程题集_003_递归算法解析

    3.递归算法: 3)传入一个Json串,返回一个字典,字典只取出Json最底层的数据, 中间如果有字符串也要进行处理,请以下面的数据为例,请用递归方法实现 Json:{"a":&q ...

  3. HTML、CSS 和 JS框架之Bootstrap

    一.Bootstrap简介: Bootstrap 是最受欢迎的 HTML.CSS 和 JS 框架,用于开发响应式布局.移动设备优先的 WEB 项目. 详细参考内容:Bootstrap_v3 二.Boo ...

  4. scrapy yield 回调函数不执行解决方案

    yield Request(url=parse.urljoin(response.url, p_url),callback=self.parse_detail) 回调函数不执行: 加上: dont_f ...

  5. JavaScript CSS 等前端推荐

    推荐两个网站,JAVASCRIPT与前端相关,两边都可以玩,蛮方便的,然后全通后你拿个全英文版本的证书提升逼格. https://www.freecodecamp.org/ https://www.f ...

  6. 基于 NodeJs 打造 Web 在线聊天室

    Socket.IO 简介与基础环境搭建 任务时间:10min ~ 20min 关于 Socket.IO Socket.IO 可以实现在浏览器和服务器之间实时双向通信,本节课程将详细介绍 Socket. ...

  7. CentOS 7中设置PHP7的Log文件日志

    对于服务器上面运行的php代码, 想要去查看对应的log,找到代码无法运行的原因 1.通过:phpinfo()去找 error_log 结果得到: 2.然后去编辑php.ini,修改三处地方 vi / ...

  8. [AI开发]基于DeepStream的视频结构化解决方案

    视频结构化的定义 利用深度学习技术实时分析视频中有价值的内容,并输出结构化数据.相比数据库中每条结构化数据记录,视频.图片.音频等属于非结构化数据,计算机程序不能直接识别非结构化数据,因此需要先将这些 ...

  9. 【转载】CentOS6.5升级手动安装GCC4.8.2

    一.简易安装 操作环境 CentOS6.5 64bit,原版本4.4.7,不能支持C++11的特性~,希望升级到4.8.2 不能通过yum的方法升级,需要自己手动下载安装包并编译 1.1 获取安装包并 ...

  10. [Kubernetes]kubectl命令补全出错

    在kubernetes集群中,命令补全能够省很多事,但是这两天就很奇怪 kubectl get pod -n kube+tab键自动补全Namespace的时候出现错误 kubectl get pod ...