ListView封装实现下拉刷新和上拉加载(方式2)(转载)
转自:http://blog.csdn.net/jdfkldjlkjdl/article/details/70229465
这次使用的是系统的SwipeRefreshLayout实现下拉刷新,和设置ListView的滑动监听判断是否滑动到最底部然后加载更多;如果想了解用另一种方式实现这个功能,请移步http://blog.csdn.net/jdfkldjlkjdl/article/details/51277941
其中,SwipeRefreshLayout的几个方法功能如下:
1、setOnRefreshListener():设置手势滑动监听器。
2、setProgressBackgroundColor():设置进度圈的背景色。
3、setColorSchemeResources():设置进度动画的颜色。
4、setRefreshing():设置组件的刷洗状态。
5、setSize():设置进度圈的大小
下面说一下实现步骤:
1.添加布局文件
- <android.support.v4.widget.SwipeRefreshLayout
- android:id="@+id/mSwipeRefreshLayout"
- android:layout_width="match_parent"
- android:layout_height="match_parent">
- <ListView
- android:id="@+id/mListView"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:divider="#cccccc"
- android:dividerHeight="1px"/>
- </android.support.v4.widget.SwipeRefreshLayout>
2.添加加载更多的布局文件load_more.xml
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:id="@+id/ll_load_more"
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:orientation="vertical">
- <LinearLayout
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_gravity="center_horizontal"
- android:layout_margin="10dip"
- android:gravity="center_vertical"
- android:orientation="horizontal">
- <ProgressBar
- android:layout_width="30dp"
- android:layout_height="30dp"
- android:layout_gravity="center"
- />
- <TextView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_marginLeft="10dip"
- android:text="加载更多"
- android:textColor="#bbb"
- android:textSize="12sp"/>
- </LinearLayout>
- </LinearLayout>
3.绑定下拉刷新事件
- //设置手势监听
- mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
- @Override
- public void onRefresh() {
- mHandler.sendEmptyMessageDelayed(REFRESH, 2000);
- }
- });
4.绑定上拉加载更多事件
- //给listview设置一个滑动的监听
- mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
- int visibleLastIndex = 0; //最后的可视项索引
- int visibleItemCount; // 当前窗口可见项总数
- //当滑动状态发生改变的时候执行
- public void onScrollStateChanged(AbsListView view, int scrollState) {
- switch (scrollState) {
- //当不滚动的时候
- case AbsListView.OnScrollListener.SCROLL_STATE_IDLE:
- int itemsLastIndex = adapter.getCount() - 1; //数据集最后一项的索引
- int lastIndex = itemsLastIndex + 1; //加上底部的loadMoreView项
- //判断是否是最底部
- //if (view.getLastVisiblePosition() == (view.getCount()) - 1) { //或者
- if (visibleLastIndex == lastIndex) {
- loadMoreView.setVisibility(View.VISIBLE);
- mHandler.postDelayed(new Runnable() {
- @Override
- public void run() {
- //加载网络数据
- Message msg = new Message();
- msg.what = LOADMORE;
- msg.arg1 = visibleLastIndex - visibleItemCount + 1;
- mHandler.sendMessage(msg);
- }
- }, 2000);
- }
- break;
- }
- }
- //正在滑动的时候执行
- public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
- this.visibleItemCount = visibleItemCount;
- visibleLastIndex = firstVisibleItem + visibleItemCount - 1;
- }
- });
完整的activity代码如下:
- package demo.xzy.qh.com.listviewpulltorefreshandloadmore;
- import android.app.Activity;
- import android.graphics.Color;
- import android.os.Bundle;
- import android.os.Handler;
- import android.os.Message;
- import android.support.v4.widget.SwipeRefreshLayout;
- import android.view.View;
- import android.widget.AbsListView;
- import android.widget.ArrayAdapter;
- import android.widget.ListView;
- import java.util.ArrayList;
- import java.util.List;
- /**
- * ListView下拉刷新,上拉加载demo
- */
- public class MainActivity extends Activity {
- private SwipeRefreshLayout mSwipeRefreshLayout;
- private ListView mListView;
- private List<String> data = new ArrayList<>();
- private ArrayAdapter<String> adapter;
- private static final int REFRESH = 0x01;
- private static final int LOADMORE = 0x02;
- private View loadMoreView;
- private Handler mHandler = new Handler() {
- @Override
- public void handleMessage(Message msg) {
- super.handleMessage(msg);
- switch (msg.what) {
- case REFRESH:
- data.add(0, "刷新得到的数据");
- adapter.notifyDataSetChanged();
- mSwipeRefreshLayout.setRefreshing(false);
- break;
- case LOADMORE:
- for (int x = 0; x < 5; x++) {
- data.add(data.size(), "aaaaaa" + x);
- }
- adapter.notifyDataSetChanged(); //数据集变化后,通知adapter
- int position = msg.arg1;
- mListView.setSelection(position); //设置选中项
- loadMoreView.setVisibility(View.GONE);
- break;
- }
- }
- };
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- for (int i = 0; i < 6; i++) {
- data.add("测试数据" + i);
- }
- initView();
- }
- private void initView() {
- mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.mSwipeRefreshLayout);
- mListView = (ListView) findViewById(R.id.mListView);
- loadMoreView = getLayoutInflater().inflate(R.layout.load_more, null);
- loadMoreView.setVisibility(View.GONE);
- mListView.addFooterView(loadMoreView);
- mListView.setFooterDividersEnabled(false);
- //设置进度圈的大小;(这里面只有两个值SwipeRefreshLayout.LARGE和DEFAULT,后者是默认效果)
- mSwipeRefreshLayout.setSize(SwipeRefreshLayout.DEFAULT);
- //设置进度圈的背景色。这里随便给他设置了一个颜色:浅绿色
- mSwipeRefreshLayout.setProgressBackgroundColorSchemeColor(Color.CYAN);
- //设置进度动画的颜色。这里面最多可以指定四个颜色,我这也是随机设置的,大家知道怎么用就可以了
- mSwipeRefreshLayout.setColorSchemeResources(android.R.color.holo_orange_dark
- , android.R.color.holo_blue_dark
- , android.R.color.holo_red_dark
- , android.R.color.widget_edittext_dark);
- adapter = new ArrayAdapter<>(MainActivity.this, android.R.layout.simple_list_item_1, data);
- mListView.setAdapter(adapter);
- //设置手势监听
- mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
- @Override
- public void onRefresh() {
- mHandler.sendEmptyMessageDelayed(REFRESH, 2000);
- }
- });
- //给listview设置一个滑动的监听
- mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
- int visibleLastIndex = 0; //最后的可视项索引
- int visibleItemCount; // 当前窗口可见项总数
- //当滑动状态发生改变的时候执行
- public void onScrollStateChanged(AbsListView view, int scrollState) {
- switch (scrollState) {
- //当不滚动的时候
- case AbsListView.OnScrollListener.SCROLL_STATE_IDLE:
- int itemsLastIndex = adapter.getCount() - 1; //数据集最后一项的索引
- int lastIndex = itemsLastIndex + 1; //加上底部的loadMoreView项
- //判断是否是最底部
- //if (view.getLastVisiblePosition() == (view.getCount()) - 1) { //或者
- if (visibleLastIndex == lastIndex) {
- loadMoreView.setVisibility(View.VISIBLE);
- mHandler.postDelayed(new Runnable() {
- @Override
- public void run() {
- //加载网络数据
- Message msg = new Message();
- msg.what = LOADMORE;
- msg.arg1 = visibleLastIndex - visibleItemCount + 1;
- mHandler.sendMessage(msg);
- }
- }, 2000);
- }
- break;
- }
- }
- //正在滑动的时候执行
- public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
- this.visibleItemCount = visibleItemCount;
- visibleLastIndex = firstVisibleItem + visibleItemCount - 1;
- }
- });
- }
- }
整个demo很简单,就两个布局文件和一个activity。
至此,标题中提到的功能已经实现。欢迎留言指正。
ListView封装实现下拉刷新和上拉加载(方式2)(转载)的更多相关文章
- android--------自定义控件ListView实现下拉刷新和上拉加载
开发项目过程中基本都会用到listView的下拉刷新和上滑加载更多,为了方便重写的ListView来实现下拉刷新,同时添加了上拉自动加载更多的功能. Android下拉刷新可以分为两种情况: 1.获取 ...
- Diycode开源项目 搭建可以具有下拉刷新和上拉加载的Fragment
1.效果预览 1.1.这个首页就是一个Fragment碎片,本文讲述的就是这个碎片的搭建方式. 下拉会有一个旋转的刷新圈,上拉会刷新数据. 1.2.整体结构 首先底层的是BaseFragment 然后 ...
- Android 5.X新特性之为RecyclerView添加下拉刷新和上拉加载及SwipeRefreshLayout实现原理
RecyclerView已经写过两篇文章了,分别是Android 5.X新特性之RecyclerView基本解析及无限复用 和 Android 5.X新特性之为RecyclerView添加Header ...
- Android 使用PullToRefresh实现下拉刷新和上拉加载(ExpandableListView)
PullToRefresh是一套实现非常好的下拉刷新库,它支持: 1.ListView 2.ExpandableListView 3.GridView 4.WebView 等多种常用的需要刷新的Vie ...
- 使用PullToRefresh实现下拉刷新和上拉加载
使用PullToRefresh实现下拉刷新和上拉加载 分类: Android2013-12-20 15:51 78158人阅读 评论(91) 收藏 举报 Android下拉刷新上拉加载PullToRe ...
- 安卓开发笔记——关于开源组件PullToRefresh实现下拉刷新和上拉加载(一分钟搞定,超级简单)
前言 以前在实现ListView下拉刷新和上拉加载数据的时候都是去继承原生的ListView重写它的一些方法,实现起来非常繁杂,需要我们自己去给ListView定制下拉刷新和上拉加载的布局文件,然后添 ...
- Android实现RecyclerView的下拉刷新和上拉载入很多其它
需求 先上效果图, Material Design风格的下拉刷新和上拉载入很多其它. 源代码地址(欢迎star) https://github.com/studychen/SeeNewsV2 假设对于 ...
- iscroll.js 下拉刷新和上拉加载
html代码如下 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- IOS 开发下拉刷新和上拉加载更多
IOS 开发下拉刷新和上拉加载更多 简介 1.常用的下拉刷新的实现方式 (1)UIRefreshControl (2)EGOTTableViewrefresh (3)AH3DPullRefresh ( ...
- IOS UITableView下拉刷新和上拉加载功能的实现
在IOS开发中UITableView是非常常用的一个功能,而在使用UITableView的时候我们经常要用到下拉刷新和上拉加载的功能,今天花时间实现了简单的UITableView的下拉刷新和上拉加载功 ...
随机推荐
- 关于C++中的非静态类成员函数指针
昨天发现了一个问题,就是使用对类中的非静态成员函数使用std::bind时,不能像普通函数一样直接传递函数名,而是必须显式地调用&(取地址),于是引申出我们今天的问题:非静态类成员函数指针和普 ...
- 转载:java集合类数据结构分析
数组是 最常用的数据结构.数组的特点是长度固定,可以用下标索引,并且所有的元素的类型都是一致的.数组常用的场景有把:从数据库里读取雇员的信息存储为 EmployeeDetail[],把一个字符串转换并 ...
- HDU-5072 补集转化+容斥原理
题意:给n个数,求满足一下条件的三元组(a,b,c)数量:a,b,c两两互质或者a,b,c两两不互质. 解法:这道题非常巧妙地运用补集转化和容斥原理.首先我们令这n个数为n个点,然后两两之间连边如果是 ...
- json_value.obj) : error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MD_DynamicRelease”不匹配值“MT_StaticReleas
注意版本的提示mD mt 注意动态mfc 还是静态mfc
- 1、selenium 8大元素定位方式
元素定位方式: id name css class_name tag_name partial_link link_text : driver. find_element_by_link_text(& ...
- Clip
网页中的渲染是由CSS来实现,CSS2就不说了,那个没得说的,最常用的就是个颜色布局什么的. CSS3 自从有了CSS3,相比CSS2变得更具有活力了,CSS3没有什么方法函数的,它跟CSS2一样也是 ...
- Nginx是什么?为什么选择Nginx做服务器软件?有什么优势?
代理服务器基础知识 Nginx是什么? 为什么选择Nginx 1.代理服务器基础知识 a.代理服务器 一般是指局域网内部的机器通过代理服务器发送请求到互联网上的服务器,代理服务器一般作用在客户端.应用 ...
- 玩玩Mybatis的逆向工程
通过数据库 逆向生成代码 主要配置的文件: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE ...
- Codeforces Round #420 (Div. 2) E. Okabe and El Psy Kongroo dp+矩阵快速幂
E. Okabe and El Psy Kongroo Okabe likes to take walks but knows that spies from the Organization c ...
- Kubernetes v1.16 对API的更改
前段时间安装Kubernetes v1.16.2,然后从v1.14版本的拷贝yaml文件过来执行,很多都报没有相应的api,查看一下新版本的api admissionregistration.k8s. ...