PullToRefresh 是一个第三方的工程。

之前的自定义下拉刷新控件貌似不太好用,于是网上找了这个。

参考:http://www.cnblogs.com/summers/p/4343964.html

主要是一些功能都提供了接口,不需要自己再写了。

废话不多说,上干货。

1、布局文件

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical" >
  6.  
  7. <!-- ptr:ptrAnimationStyle="flip" flip:翻转 rotate:旋转-->
  8. <!-- ptr:ptrShowIndicator="true" 右上角 右下角出现箭头-->
  9. <com.handmark.pulltorefresh.library.PullToRefreshListView
  10. xmlns:ptr="http://schemas.android.com/apk/res-auto"
  11. android:id="@+id/pullToRefresh"
  12. android:layout_width="match_parent"
  13. android:layout_height="wrap_content"
  14. ptr:ptrDrawable="@drawable/default_ptr_flip"
  15. ptr:ptrAnimationStyle="flip"
  16. ptr:ptrHeaderBackground="#383838"
  17. ptr:ptrHeaderTextColor="#FFFFFF"
  18. />
  19.  
  20. </LinearLayout>

其中有一些属性需要说明,

ptr是pullToRefresh的配置属性 使用是需要添加 xmlns:ptr="http://schemas.android.com/apk/res-auto"

ptr:ptrDrawable=“” 上拉下拉图标

ptr:ptrAnimationStyle=""  图标动画  取值: flip:翻转 rotate旋转

ptr:ptrHeaderBackground=""  上拉下拉时 头部的背景色

ptr:ptrHeaderTextColor=""     上拉下拉时 文字颜色

ptrRefreshableViewBackground 设置整个mPullRefreshListView的背景色

ptrScrollingWhileRefreshingEnabled刷新的时候,是否允许ListView或GridView滚动。觉得为true比较好。(这个本人亲测,不支持这个属性,不知道为什么)

ptrListViewExtrasEnabled 决定了Header,Footer以何种方式加入mPullRefreshListView,true为headView方式加入,就是滚动时刷新头部会一起滚动。(这个本人亲测,不支持这个属性,不知道为什么)

注:上述属性都可以代码添加,请用pullToRefresh.set查看

2、MainActivity代码

  1. public class MainActivity extends ActionBarActivity {
  2.  
  3. private PullToRefreshListView pullToRefresh;
  4. private List<PullBean> data = new ArrayList<PullBean>();
  5. MyAdapter adapter;
  6. @Override
  7. protected void onCreate(Bundle savedInstanceState) {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.main);
  10. pullToRefresh = (PullToRefreshListView) findViewById(R.id.pullToRefresh);
  11. data = getData();
  12. adapter = new MyAdapter(this);
  13. pullToRefresh.setAdapter(adapter);
  14. /*
  15. * Mode.BOTH:同时支持上拉下拉
  16. * Mode.PULL_FROM_START:只支持下拉Pulling Down
  17. * Mode.PULL_FROM_END:只支持上拉Pulling Up
  18. */
  19. /*
  20. * 如果Mode设置成Mode.BOTH,需要设置刷新Listener为OnRefreshListener2,并实现onPullDownToRefresh()、onPullUpToRefresh()两个方法。
  21. * 如果Mode设置成Mode.PULL_FROM_START或Mode.PULL_FROM_END,需要设置刷新Listener为OnRefreshListener,同时实现onRefresh()方法。
  22. * 当然也可以设置为OnRefreshListener2,但是Mode.PULL_FROM_START的时候只调用onPullDownToRefresh()方法,
  23. * Mode.PULL_FROM的时候只调用onPullUpToRefresh()方法.
  24. */
  25. pullToRefresh.setMode(Mode.BOTH);
  26. init();
  27.  
  28. /*
  29. * setOnRefreshListener(OnRefreshListener listener):设置刷新监听器;
  30. * setOnLastItemVisibleListener(OnLastItemVisibleListener listener):设置是否到底部监听器;
  31. * setOnPullEventListener(OnPullEventListener listener);设置事件监听器;
  32. * onRefreshComplete():设置刷新完成
  33. */
  34. /*
  35. * pulltorefresh.setOnScrollListener()
  36. */
  37. // SCROLL_STATE_TOUCH_SCROLL(1) 正在滚动
  38. // SCROLL_STATE_FLING(2) 手指做了抛的动作(手指离开屏幕前,用力滑了一下)
  39. // SCROLL_STATE_IDLE(0) 停止滚动
  40. /*
  41. * setOnLastItemVisibleListener
  42. * 当用户拉到底时调用
  43. */
  44. /*
  45. * setOnTouchListener是监控从点下鼠标 (可能拖动鼠标)到放开鼠标(鼠标可以换成手指)的整个过程 ,他的回调函数是onTouchEvent(MotionEvent event),
  46. * 然后通过判断event.getAction()是MotionEvent.ACTION_UP还是ACTION_DOWN还是ACTION_MOVE分别作不同行为。
  47. * setOnClickListener的监控时间只监控到手指ACTION_DOWN时发生的行为
  48. */
  49. pullToRefresh.setOnRefreshListener(new OnRefreshListener2<ListView>(){
  50. @Override
  51. public void onPullDownToRefresh(
  52. PullToRefreshBase<ListView> refreshView) {
  53. // TODO Auto-generated method stub
  54. PullBean bean = new PullBean();
  55. bean.setTitle("下拉刷新");
  56. bean.setContent("我的神");
  57. adapter.addFirst(bean);
  58. new FinishRefresh().execute();
  59. adapter.notifyDataSetChanged();
  60. }
  61.  
  62. @Override
  63. public void onPullUpToRefresh(
  64. PullToRefreshBase<ListView> refreshView) {
  65. // TODO Auto-generated method stub
  66. PullBean bean = new PullBean();
  67. bean.setTitle("上拉刷新");
  68. bean.setContent("我的神");
  69. adapter.addLast(bean);
  70. new FinishRefresh().execute();
  71. adapter.notifyDataSetChanged();
  72. }
  73. });
  74.  
  75. // pullToRefresh.setOnRefreshListener(new OnRefreshListener<ListView>() {
  76. //
  77. // @Override
  78. // public void onRefresh(PullToRefreshBase<ListView> refreshView) {
  79. // // TODO Auto-generated method stub
  80. // String label = DateUtils.formatDateTime(getApplicationContext(), System.currentTimeMillis(),
  81. // DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_ALL);
  82. //
  83. // // Update the LastUpdatedLabel
  84. // refreshView.getLoadingLayoutProxy().setLastUpdatedLabel(label);
  85. // PullBean bean = new PullBean();
  86. // bean.setTitle("我的神");
  87. // bean.setContent("我的神");
  88. // adapter.addFirst(bean);
  89. // new FinishRefresh().execute();
  90. // }
  91. //
  92. // });
  93. }
  94.  
  95. private void init()
  96. {
  97. ILoadingLayout startLabels = pullToRefresh
  98. .getLoadingLayoutProxy(true, false);
  99. startLabels.setPullLabel("下拉刷新...");// 刚下拉时,显示的提示
  100. startLabels.setRefreshingLabel("正在载入...");// 刷新时
  101. startLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
  102.  
  103. ILoadingLayout endLabels = pullToRefresh.getLoadingLayoutProxy(
  104. false, true);
  105. endLabels.setPullLabel("上拉刷新...");// 刚下拉时,显示的提示
  106. endLabels.setRefreshingLabel("正在载入...");// 刷新时
  107. endLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
  108.  
  109. // // 设置下拉刷新文本
  110. // pullToRefresh.getLoadingLayoutProxy(false, true)
  111. // .setPullLabel("上拉刷新...");
  112. // pullToRefresh.getLoadingLayoutProxy(false, true).setReleaseLabel(
  113. // "放开刷新...");
  114. // pullToRefresh.getLoadingLayoutProxy(false, true).setRefreshingLabel(
  115. // "正在加载...");
  116. // // 设置上拉刷新文本
  117. // pullToRefresh.getLoadingLayoutProxy(true, false)
  118. // .setPullLabel("下拉刷新...");
  119. // pullToRefresh.getLoadingLayoutProxy(true, false).setReleaseLabel(
  120. // "放开刷新...");
  121. // pullToRefresh.getLoadingLayoutProxy(true, false).setRefreshingLabel(
  122. // "正在加载...");
  123. }
  124.  
  125. private List<PullBean> getData(){
  126. List<PullBean> list = new ArrayList<PullBean>();
  127. for(int i = 0;i < 10;i ++){
  128. PullBean bean = new PullBean();
  129. bean.setTitle("item " + i + " 搜索业务增速下滑 Google廉颇老矣?");
  130. bean.setContent("Google于10月17日发布了2014年第三季度财报");
  131. list.add(bean);
  132. }
  133.  
  134. return list;
  135. }
  136.  
  137. private class FinishRefresh extends AsyncTask<Void, Void, Void>{
  138. @Override
  139. protected Void doInBackground(Void... params) {
  140. try {
  141. Thread.sleep(1000);
  142. } catch (InterruptedException e) {
  143. }
  144. return null;
  145. }
  146.  
  147. @Override
  148. protected void onPostExecute(Void result){
  149. // adapter.notifyDataSetChanged();
  150. pullToRefresh.onRefreshComplete();
  151. }
  152. }
  153.  
  154. private class MyAdapter extends BaseAdapter{
  155. private LayoutInflater mInflater;
  156.  
  157. public MyAdapter(Context context) {
  158. // TODO Auto-generated constructor stub
  159. mInflater = LayoutInflater.from(context);
  160. }
  161.  
  162. public void addFirst(PullBean bean){
  163. data.add(0, bean);
  164. }
  165.  
  166. public void addLast(PullBean bean){
  167. data.add(bean);
  168. }
  169.  
  170. @Override
  171. public int getCount() {
  172. // TODO Auto-generated method stub
  173. return data.size();
  174. }
  175.  
  176. @Override
  177. public Object getItem(int position) {
  178. // TODO Auto-generated method stub
  179. return data.get(position);
  180. }
  181.  
  182. @Override
  183. public long getItemId(int position) {
  184. // TODO Auto-generated method stub
  185. return 0;
  186. }
  187.  
  188. @Override
  189. public View getView(int position, View convertView, ViewGroup parent) {
  190. // TODO Auto-generated method stub
  191. ViewHolder viewHolder = null;
  192. if(convertView == null){
  193. viewHolder = new ViewHolder();
  194. convertView = mInflater.inflate(R.layout.item, null);
  195. viewHolder.title = (TextView) convertView.findViewById(R.id.title);
  196. viewHolder.content = (TextView) convertView.findViewById(R.id.content);
  197.  
  198. convertView.setTag(viewHolder);
  199. }else{
  200. viewHolder = (ViewHolder) convertView.getTag();
  201. }
  202.  
  203. viewHolder.title.setText(data.get(position).getTitle());
  204. viewHolder.content.setText(data.get(position).getContent());
  205.  
  206. return convertView;
  207. }
  208.  
  209. class ViewHolder{
  210. TextView title;
  211. TextView content;
  212. }
  213. }
  214.  
  215. }

pullToRefresh适配器Adapter和listview也是继承于BaseAdapter 看一下item的布局

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:padding="5dp"
  6. android:orientation="vertical" >
  7.  
  8. <TextView
  9. android:id="@+id/title"
  10. android:layout_width="wrap_content"
  11. android:layout_height="wrap_content"
  12. android:textSize="18sp"
  13. android:textColor="#BA55D3"
  14. android:text="我的神"/>
  15.  
  16. <TextView
  17. android:id="@+id/content"
  18. android:layout_width="wrap_content"
  19. android:layout_height="wrap_content"
  20. android:textSize="14.0sp"
  21. android:layout_marginTop="5dp"
  22. android:textColor="#7CFC00"
  23. android:text="我的神"/>
  24. </LinearLayout>

pullToRefresh 通过setMode来设置是否可以上拉下拉

Mode.BOTH:同时支持上拉下拉

Mode.PULL_FROM_START:只支持下拉Pulling Down

Mode.PULL_FROM_END:只支持上拉Pulling Up

也可以用 ptr:ptrMode="both"

可选值为:disabled(禁用下拉刷新),pullFromStart(仅支持下拉刷新),pullFromEnd(仅支持上拉刷新),both(二者都支持),manualOnly(只允许手动触发)

如果Mode设置成Mode.BOTH,需要设置刷新Listener为OnRefreshListener2,并实现onPullDownToRefresh()、onPullUpToRefresh()两个方法。

如果Mode设置成Mode.PULL_FROM_START或Mode.PULL_FROM_END,需要设置刷新Listener为OnRefreshListener,同时实现onRefresh()方法。

当然也可以设置为OnRefreshListener2,但是Mode.PULL_FROM_START的时候只调用onPullDownToRefresh()方法,Mode.PULL_FROM的时候只调用onPullUpToRefresh()方法.

如果想上拉、下拉刷新的时候 做一样的操作,那就用OnRefreshListener,上拉下拉的时候都调用

如果想上拉、下拉做不一样的的操作,那就在setOnRefreshListener时 用new OnRefreshListener2<ListView>

当然如果想自己设置上拉下拉中的文字 可以这样

  1. pullToRefresh.getLoadingLayoutProxy(false, true)
  2. .setPullLabel("上拉刷新...");
  3. pullToRefresh.getLoadingLayoutProxy(false,true)
  4. .setReleaseLabel( "放开刷新...");
  5. pullToRefresh.getLoadingLayoutProxy(false,true)
  6. .setRefreshingLabel("正在加载...");
  7. // 设置上拉刷新文本
  8. pullToRefresh.getLoadingLayoutProxy(true, false)
  9. .setPullLabel("下拉刷新...");
  10. pullToRefresh.getLoadingLayoutProxy(true,false)
  11. .setReleaseLabel("放开刷新...");
  12. pullToRefresh.getLoadingLayoutProxy(true,false)
  13. .setRefreshingLabel( "正在加载...");

显然在实际操作的时候也会用到其他监听

setOnScrollListener()

SCROLL_STATE_TOUCH_SCROLL 正在滚动      SCROLL_STATE_FLING 手指做了抛的动作(手指离开屏幕前,用力滑了一下)      SCROLL_STATE_IDLE 停止滚动

setOnLastItemVisibleListener

当用户拉到底时调用

setOnItemClickListener()

为pullToRefresh中每一个item设置事件

代码下载:点击下载代码

下拉上拉 图标和文字 位置改动是在PullToRefresh源代码中改的即:PullToRefreshListView.handleStyledAttributes 中lp的Gravity改为CENTER_VERTICAL

如果想要改动图标和文字的距离和布局 在这library项目下这两个文件改

pull_to_refresh_header_horizontal.xml

pull_to_refresh_header_vertical.xml

pullToRefresh下拉刷新上拉加载的更多相关文章

  1. Android 下拉刷新上啦加载SmartRefreshLayout + RecyclerView

    在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/de ...

  2. SwipeRefreshLayout实现下拉刷新上滑加载

    1. 效果图 2.RefreshLayout.java package myapplication.com.myapplication; import android.content.Context; ...

  3. 移动端下拉刷新上拉加载-mescroll.js插件

    最近无意间看到有这么一个上拉刷新下拉加载的插件 -- mescroll.js,个人感觉挺好用的,官网地址是:http://www.mescroll.com 然后我就看了一下文档,简单的写了一个小dem ...

  4. JS+CSS实现的下拉刷新/上拉加载插件

    闲来无事,写了一个当下比较常见的下拉刷新/上拉加载的jquery插件,代码记录在这里,有兴趣将代码写成插件与npm包可以留言. 体验地址:http://owenliang.github.io/pull ...

  5. RecyclerView下拉刷新上拉加载(一)

    listview下拉刷新上拉加载扩展(一) http://blog.csdn.net/baiyuliang2013/article/details/50252561 listview下拉刷新上拉加载扩 ...

  6. 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载

    title: 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载 tags: -RecyclerView,下拉刷新,上拉加载更多 grammar_cjkRuby: true - ...

  7. ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多

    ListView实现Item上下拖动交换位置  并且实现下拉刷新  上拉加载更多 package com.example.ListViewDragItem; import android.app.Ac ...

  8. [ionic开源项目教程] - 第7讲 实现下拉刷新上拉加载ion-refresher和ion-infinite-scroll

    第7讲 实现下拉刷新上拉加载ion-refresher和ion-infinite-scroll 1.将tab1.html的代码改为如下: <ion-content> <ion-ref ...

  9. 基于SwiperJs的H5/移动端下拉刷新上拉加载更多的效果

    最早时,公司的H5项目中曾用过点击一个"加载更多"的DOM元素来实现分页的功能,后来又用过网上有人写的一个上拉加载更多的插件,那个插件是页面将要滚动到底部时就自动请求数据并插入到页 ...

  10. ListView下拉刷新上拉加载更多实现

    这篇文章将带大家了解listview下拉刷新和上拉加载更多的实现过程,先看效果(注:图片中listview中的阴影可以加上属性android:fadingEdge="none"去掉 ...

随机推荐

  1. logstash 1.5.3 配置使用redis做续传

    logstash是ELK中的一员大将, redis插件也是<The Logstash Book>中介绍的一个很好用的玩意儿. 之前,用比较小的集群部署的时候,没有介入redis中间件,所以 ...

  2. throw和throws的区别

    1.      作用不同: throw用于在程序中抛出异常;throws用于声明在该方法内抛出异常, 2.      使用位置不同:throw位于方法体内部,可以作为单独语句使用,throws必须跟着 ...

  3. 关于JQuery的一些知识点

    1.jQuery的入口函数 1.1 语法jQuery(document).read(function(){ }); $(function(){ });// ** window.onlaod = fun ...

  4. 'Invalid parameter not satisfying: body'

    afnetwork图片上传的时候出错,出现错误 2015-11-09 15:47:59.086 videoPro[3207:132795] *** Assertion failure in -[AFS ...

  5. PHP连接SQLServer

    连接前配置系统: 1.检查文件 php5.2.5/ntwdblib.dll 默认下面有一个,不能连接再替换. 下载正确版本的 ntwdblib.dll (2000.80.194.0),地址: http ...

  6. openldap加密传输 nslcd

    http://www.openldap.org/faq/data/cache/185.html https://www.ibm.com/developerworks/cn/linux/1312_zha ...

  7. NK3C程序配置

    1.坐席软电话 1)NKZXAgent 1)需要环境:.netframework 4.0 2)reg.bat 注册:(确认注册成功) 3)TestAgt.exe 软电话签入测试 LoadConfig: ...

  8. 配置zabbix当内存剩余不足10%的时候触发报警

    配置zabbix当内存剩余不足10%的时候触发报警 zabbix默认的剩余内存报警: Average Lack of available memory on server {HOST.NAME}{Te ...

  9. mongoDB 使用手册

      1.基本操作db.AddUser(username,password) 添加用户db.auth(usrename,password) 设置数据库连接验证db.cloneDataBase(fromh ...

  10. usb host驱动

    参考 http://blog.csdn.net/star530/article/details/8019604