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的下拉刷新和上拉加载功 ...
随机推荐
- css3--文字效果
text-shadow <!DOCTYPE html> <html> <head> <meta charset="utf-8"> & ...
- H5 移动调试全攻略
H5 移动调试全攻略 随着移动设备的高速发展,H5 开发也成为了 F2E 不可或缺的能力.而移动开发的重中之重就是掌握调试技巧,定 Bug于无形. 一.概要 因为移动端操作系统分为 iOS 和 And ...
- PC-lint初体验
当时用lint安装到VS2008上,找到两篇比较好的帖子: https://www.cnblogs.com/sanghg/p/4550829.html //这个 ...
- Es学习第三课, ElasticSearch基本的增删改查
前面两课我们了解了ES的基本概念并且学会了安装ES,这节课我们就来讲讲ES基本的增删改查:ES主要对外界提供的是REST风格的API,我们通过客户端操作ES本质上就是API的调用.在第一课我们就讲了索 ...
- activemq消息中间件的依赖
<dependencies> <dependency> <groupId>org.apache.activemq</groupId> <artif ...
- IPv6时代已来:双十一中的IPv6大规模应用实践
摘要: 刚刚过去的双十一,大家对猫晚.抢红包.组团购还记忆犹新.大家不了解的是,不知不觉间,你可能已经成为首批互联网IPv6用户了.今年天猫双十一期间,阿里巴巴全面支持了IPv6,这是IPv6在我国的 ...
- 在idea下开发出现404错误
用idea开发时,我们一般要设置project strucure里的Modules-Sources,里面对应的有Sources,tests,Resources,Test Resources, Excl ...
- 科学把妹法 ( ̄▽ ̄)"
曾经有一位生物学人士,公布了工科把妹第一弹,暨“巴甫洛夫把妹法”: 每天给你那位心仪的女同事/女同学的抽屉里都放上精心准备的早餐,并且保持缄默不语,无论她如何询问,都不要说话. 如此坚持一至两个月, ...
- 芒果学院Python高级开发课程
- css 导航菜单+下拉菜单
一.导航菜单 1.横向导航 代码如下: <!doctype html> <html> <head> <meta charset="utf-8&quo ...