前言:前几天写了篇关于PullToRefresh控件的DEMO导入的博客,但由于当时没有用到,所以就没细往下讲,现在开始到了实战阶段,用到了PullToRefresh的listView样式,网上有讲的,但讲的不多,而且没有详细的例子来说,下面我讲讲这个东东的实现方法。这个例子对应PullToRefreshDemo里的第一个选项ListView;

注意:本篇仅写的如何实现下拉刷新,对于上拉加载的问题,参见《使用PullToRefresh实现下拉刷新和上拉加载》

相关文章:

1、《List控件使用--SimpleAdapter使用详解(一)

2、《List控件使用--SimpleAdapter使用详解(二)

3、《PullToRefresh使用详解(二)---重写BaseAdapter实现复杂XML下拉刷新》

4、《PullToRefresh使用详解(三)--实现异步加载的下拉刷新列表》

5、《PullToRefresh使用详解(四)--利用回调函数实现到底加载》

6、《PullToRefresh使用详解(五)--下拉刷新的ScrollView》

效果图: 

                               正在刷新                                                                       刷新后

      

一、导入Library

下载源码后(https://github.com/chrisbanes/Android-PullToRefresh),里面有个Library工程,添加工程到Eclipse中;

另外extras文件夹还有两个工程:PullToRefreshListFragment和PullToRefreshViewPager,由于我们的这个用不到他们的库文件,所以不必导入了;

二、实战

1、新建工程,添加Libray库到工程中

新建工程(try_PullToRefresh)后,右键-》Properties-》Android-》Add  选择上面的Library,然后就是这个样子的

2、重写activity_main.xml

XML内容为:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical" >
  6. <!--     The PullToRefreshListView replaces a standard ListView widget. -->
  7. <com.handmark.pulltorefresh.library.PullToRefreshListView
  8. android:id="@+id/pull_refresh_list"
  9. android:layout_width="fill_parent"
  10. android:layout_height="fill_parent"
  11. android:cacheColorHint="#00000000"
  12. android:divider="#19000000"
  13. android:dividerHeight="4dp"
  14. android:fadingEdge="none"
  15. android:fastScrollEnabled="false"
  16. android:footerDividersEnabled="false"
  17. android:headerDividersEnabled="false"
  18. android:smoothScrollbar="true" />
  19. </LinearLayout>

其中中间那一大段<com.handmark.pull………………/>就是相当于ListView控件,用这段来代替原是ListView控件的代码

3、JAVA代码讲解

全部代码:

  1. package com.example.try_pulltorefresh;
  2. import java.util.Arrays;
  3. import java.util.LinkedList;
  4. import com.handmark.pulltorefresh.library.PullToRefreshBase;
  5. import com.handmark.pulltorefresh.library.PullToRefreshListView;
  6. import com.handmark.pulltorefresh.library.PullToRefreshBase.OnRefreshListener;
  7. import android.os.AsyncTask;
  8. import android.os.Bundle;
  9. import android.app.Activity;
  10. import android.text.format.DateUtils;
  11. import android.widget.ArrayAdapter;
  12. import android.widget.ListView;
  13. public class MainActivity extends Activity {
  14. private String[] mStrings = { "Abbaye de Belloc", "Abbaye du Mont des Cats", "Abertam", "Abondance", "Ackawi",
  15. "Acorn", "Adelost", "Affidelice au Chablis", "Afuega'l Pitu", "Airag", "Airedale", "Aisy Cendre",
  16. "Allgauer Emmentaler", "Abbaye de Belloc", "Abbaye du Mont des Cats", "Abertam", "Abondance", "Ackawi",
  17. "Acorn", "Adelost", "Affidelice au Chablis", "Afuega'l Pitu", "Airag", "Airedale", "Aisy Cendre",
  18. "Allgauer Emmentaler" };
  19. private LinkedList<String> mListItems;
  20. private PullToRefreshListView mPullRefreshListView;
  21. private ArrayAdapter<String> mAdapter;
  22. @Override
  23. protected void onCreate(Bundle savedInstanceState) {
  24. super.onCreate(savedInstanceState);
  25. setContentView(R.layout.activity_main);
  26. mPullRefreshListView = (PullToRefreshListView) findViewById(R.id.pull_refresh_list);
  27. // Set a listener to be invoked when the list should be refreshed.
  28. mPullRefreshListView.setOnRefreshListener(new OnRefreshListener<ListView>() {
  29. @Override
  30. public void onRefresh(PullToRefreshBase<ListView> refreshView) {
  31. String label = DateUtils.formatDateTime(getApplicationContext(), System.currentTimeMillis(),
  32. DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_ALL);
  33. // Update the LastUpdatedLabel
  34. refreshView.getLoadingLayoutProxy().setLastUpdatedLabel(label);
  35. // Do work to refresh the list here.
  36. new GetDataTask().execute();
  37. }
  38. });
  39. mListItems = new LinkedList<String>();
  40. mListItems.addAll(Arrays.asList(mStrings));
  41. mAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, mListItems);
  42. //这两个绑定方法用其一
  43. // 方法一
  44. //       mPullRefreshListView.setAdapter(mAdapter);
  45. //方法二
  46. ListView actualListView = mPullRefreshListView.getRefreshableView();
  47. actualListView.setAdapter(mAdapter);
  48. }
  49. private class GetDataTask extends AsyncTask<Void, Void, String> {
  50. //后台处理部分
  51. @Override
  52. protected String doInBackground(Void... params) {
  53. // Simulates a background job.
  54. try {
  55. Thread.sleep(1000);
  56. } catch (InterruptedException e) {
  57. }
  58. String str="Added after refresh...I add";
  59. return str;
  60. }
  61. //这里是对刷新的响应,可以利用addFirst()和addLast()函数将新加的内容加到LISTView中
  62. //根据AsyncTask的原理,onPostExecute里的result的值就是doInBackground()的返回值
  63. @Override
  64. protected void onPostExecute(String result) {
  65. //在头部增加新添内容
  66. mListItems.addFirst(result);
  67. //通知程序数据集已经改变,如果不做通知,那么将不会刷新mListItems的集合
  68. mAdapter.notifyDataSetChanged();
  69. // Call onRefreshComplete when the list has been refreshed.
  70. mPullRefreshListView.onRefreshComplete();
  71. super.onPostExecute(result);
  72. }
  73. }
  74. }

代码讲解:
1、变量定义

  1. private LinkedList<String> mListItems;    //显示的列表对应原字符串
  2. private PullToRefreshListView mPullRefreshListView;  //PullToRefreshListView实例
  3. private ArrayAdapter<String> mAdapter;  //ListView的适配器

2、在OnCreate()中主要分为两步
(1)初始化mPullRefreshListView并设置监听器,以执行当需要刷新时,应该怎么办,至于真正执行刷新的类GetDataTask()我们后面再细讲,对应代码为:

  1. mPullRefreshListView = (PullToRefreshListView) findViewById(R.id.pull_refresh_list);
  2. // Set a listener to be invoked when the list should be refreshed.
  3. mPullRefreshListView.setOnRefreshListener(new OnRefreshListener<ListView>() {
  4. @Override
  5. public void onRefresh(PullToRefreshBase<ListView> refreshView) {
  6. String label = DateUtils.formatDateTime(getApplicationContext(), System.currentTimeMillis(),
  7. DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_ALL);
  8. // Update the LastUpdatedLabel
  9. refreshView.getLoadingLayoutProxy().setLastUpdatedLabel(label);
  10. // Do work to refresh the list here.
  11. new GetDataTask().execute();
  12. }
  13. });

(2)设置适配器列表内容,并与ListView绑定以显示出来,对应代码为:

  1. //设置列表内容
  2. mListItems = new LinkedList<String>();
  3. mListItems.addAll(Arrays.asList(mStrings));
  4. mAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, mListItems);
  5. //这两个绑定方法用其一
  6. // 方法一
  7. //       mPullRefreshListView.setAdapter(mAdapter);
  8. //方法二
  9. ListView actualListView = mPullRefreshListView.getRefreshableView();
  10. actualListView.setAdapter(mAdapter);

3、执行刷新的类GetDataTask()
先贴出这段代码来:

  1. private class GetDataTask extends AsyncTask<Void, Void, String> {//定义返回值的类型
  2. // 后台处理部分
  3. @Override
  4. protected String doInBackground(Void... params) {
  5. // Simulates a background job.
  6. try {
  7. Thread.sleep(1000);
  8. } catch (InterruptedException e) {
  9. }
  10. String str="Added after refresh...I add";
  11. return str;
  12. }
  13. //这里是对刷新的响应,可以利用addFirst()和addLast()函数将新加的内容加到LISTView中
  14. //根据AsyncTask的原理,onPostExecute里的result的值就是doInBackground()的返回值
  15. @Override
  16. protected void onPostExecute(String result) {
  17. //在头部增加新添内容
  18. mListItems.addFirst(result);
  19. //通知程序数据集已经改变,如果不做通知,那么将不会刷新mListItems的集合
  20. mAdapter.notifyDataSetChanged();
  21. // Call onRefreshComplete when the list has been refreshed.
  22. mPullRefreshListView.onRefreshComplete();
  23. super.onPostExecute(result);//这句是必有的,AsyncTask规定的格式
  24. }
  25. }

(1)派生自AsyncTask

由于派生自AsyncTask,所以下面的那个函数doInBackground和onPostExecute就不难理解了,这两个函数是AsyncTask必须是重写的两个函数
(2)doInBackground函数

doInBackground执行要于后台执行的语句,返回的值可以是任意类型,但要提前在extends AsyncTask<Void, Void, String> 中定义,这个返回值会做为onPostExecute的参数result传到onPostExecute函数中;如果对于网络访问程序,doInBackground就执行访问网络的代码,然后讲返回值存在result中传给onPostExecute函数,以刷新列表;

(3)onPostExecute函数

onPostExecute()是对返回的值进行操作,并添加到ListView的列表中,有两种添加方式添加到头部----mListItems.addFirst(result);和添加在尾部----mListItems.addLast(result);

至于 AsyncTask,下面是几个网页,讲的还可以,大家可以参考下:

《android AsyncTask 详解》:http://www.eoeandroid.com/thread-168004-1-1.html

《android AsyncTask 详解》(同名):http://blog.csdn.net/dabizime/article/details/6695705

《android之AsyncTask》:http://blog.csdn.net/singwhatiwanna/article/details/9272195

《Android源码分析--带你认识不一样的AsyncTask》:http://blog.csdn.net/singwhatiwanna/article/details/17596225 (绝对精品)

 另外:

1、设置向上拉刷新还是向下拉刷新的代码:

mPullRefreshListView.setMode(Mode.PULL_FROM_END);//向下拉刷新

mPullRefreshListView.setMode(Mode.PULL_FROM_START);//向上拉刷新

mPullRefreshListView.setMode(Mode.BOTH);//两端刷新

注意:这只是一个精简版,在源码中还有一些可借签的代码,可以在看懂这个以后,可以回过头来再看看源码,我相信肯定会有收获的。

源码来啦:http://download.csdn.net/detail/harvic880925/6788247(不要分,仅供分享)

 

请大家尊重原创者版权,转载请标明出处:http://blog.csdn.net/harvic880925/article/details/17680305

版权声明:本文为博主原创文章,未经博主允许不得转载。

 

PullToRefresh使用详解(一)--构建下拉刷新的listView的更多相关文章

  1. 84、PullToRefresh使用详解

    PullToRefresh使用详解(一)--构建下拉刷新的listView http://blog.csdn.net/harvic880925/article/details/17680305 Pul ...

  2. PullToRefresh下拉刷新 加载更多 详解 +示例

    常用设置 项目地址:https://github.com/chrisbanes/Android-PullToRefresh a. 设置刷新模式 如果Mode设置成Mode.PULL_FROM_STAR ...

  3. pullToRefresh下拉刷新上拉加载

    PullToRefresh 是一个第三方的工程. 之前的自定义下拉刷新控件貌似不太好用,于是网上找了这个. 参考:http://www.cnblogs.com/summers/p/4343964.ht ...

  4. 安卓开发笔记——关于开源组件PullToRefresh实现下拉刷新和上拉加载(一分钟搞定,超级简单)

    前言 以前在实现ListView下拉刷新和上拉加载数据的时候都是去继承原生的ListView重写它的一些方法,实现起来非常繁杂,需要我们自己去给ListView定制下拉刷新和上拉加载的布局文件,然后添 ...

  5. 安卓---下拉刷新---上拉加载---解决导入library等自生成库文件失败的问题

    本文的下拉刷新以及上拉加载都是用PullToRefresh实现的,关于PullToRefresh的介绍以及源码,网上可以找到很多,本人在此不再赘述. PullToRefresh是一套实现非常好的下拉刷 ...

  6. Android自定义控件之仿美团下拉刷新

    美团的下拉刷新分为三个状态: 第一个状态为下拉刷新状态(pull to refresh),在这个状态下是一个绿色的椭圆随着下拉的距离动态改变其大小. 第二个部分为放开刷新状态(release to r ...

  7. Android自定义之ScrollView下拉刷新

    公司项目,需要用到ScrollView的下拉刷新,一开始使用的时候PullToRefresh三方库的下拉刷新,我比较纠结第三档库,很强大,但是,公司项目的需求,PullToRefresh就不能做到了, ...

  8. Android之自定义控件-下拉刷新

    实现效果: 图片素材:         --> 首先, 写先下拉刷新时的刷新布局 pull_to_refresh.xml: <resources> <string name=& ...

  9. [转]Android下拉刷新完全解析,教你如何一分钟实现下拉刷新功能

    版权声明:本文出自郭霖的博客,转载必须注明出处. 转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9255575 最近项目中需要用到L ...

随机推荐

  1. 回溯法练习【BFS/DFS】

    1.N皇后问题 2.油田问题 3.素数环问题 4.马踏棋盘问题 5.图的m着色问题 6.01背包问题 7.TSP问题 [Code-1:输出N皇后方案和个数] #include<bits/stdc ...

  2. 洛谷——P1591 阶乘数码

    P1591 阶乘数码 题目描述 求n!中某个数码出现的次数. 输入输出格式 输入格式: 第一行为t(≤10),表示数据组数.接下来t行,每行一个正整数n(≤1000)和数码a. 输出格式: 对于每组数 ...

  3. HDU2923 Einbahnstrasse (Floyd)

    Einbahnstrasse Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  4. 36、Django实战第36天:首页功能开发

    1.编辑users.views.py ... class IndexView(View): """ 首页 """ def get(self, ...

  5. 【字符串哈希】bzoj3916 [Baltic2014]friends

    枚举断点,哈希判断. #include<cstdio> using namespace std; typedef unsigned long long ull; ull hs,hs1,hs ...

  6. [TC-HouseProtection]House Protection

    题目大意: 一个平面直角坐标系中有给定的$n(n\le50)$个红点和$m(m\le50)$个蓝点,每个点可以选择画一个半径为$r$(所有的$r$相同)的圆或不画.圆的半径上限为$R(R\le1000 ...

  7. Scala高手实战****第20课:Scala提取器、注解深度实战详解及Spark源码鉴赏

    Spark中的源码的提取器和注解 @SparkContext.scala @ volatile 线程专用 保证线程间共享内容的一致性 @volatile private var _dagSchedul ...

  8. iOS中的场景转换机制的浅显分析

    目前Apple推荐的场景转换的方法有以下几个: 一般的跳转方法: presentViewController Discussion In a horizontally compact environm ...

  9. OC语言基础之NSDictionary

    1.NSDictionary字典的创建 1: // key value 2: // key -==> value 3: NSDictionary *dict = [NSDictionary di ...

  10. dependency:copy-dependencies使用,如何排除应用自身module

    相信用法参考:https://maven.apache.org/plugins/maven-dependency-plugin/copy-dependencies-mojo.html#includeG ...