PullToRefreshListView 应用讲解
转载于http://blog.csdn.net/mmjiajia132/article/details/40397813
PullToRefreshListView 用法和ListView 没有什么区别 listview能用的属性 pulltorefresh也能用
我一直认为动手是最好的学习方法...
一:首先看布局文件
- <?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" >
- <!-- ptr:ptrAnimationStyle="flip" flip:翻转 rotate:旋转-->
- <!-- ptr:ptrShowIndicator="true" 右上角 右下角出现箭头-->
- <com.handmark.pulltorefresh.library.PullToRefreshListView
- xmlns:ptr="http://schemas.android.com/apk/res-auto"
- android:id="@+id/pullToRefresh"
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- ptr:ptrDrawable="@drawable/default_ptr_flip"
- ptr:ptrAnimationStyle="flip"
- ptr:ptrHeaderBackground="#383838"
- ptr:ptrHeaderTextColor="#FFFFFF"
- />
- </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查看
二:MainActivity代码
- public class MainActivity extends ActionBarActivity {
- private PullToRefreshListView pullToRefresh;
- private List<PullBean> data = new ArrayList<PullBean>();
- MyAdapter adapter;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- pullToRefresh = (PullToRefreshListView) findViewById(R.id.pullToRefresh);
- data = getData();
- adapter = new MyAdapter(this);
- pullToRefresh.setAdapter(adapter);
- /*
- * Mode.BOTH:同时支持上拉下拉
- * Mode.PULL_FROM_START:只支持下拉Pulling Down
- * Mode.PULL_FROM_END:只支持上拉Pulling Up
- */
- /*
- * 如果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()方法.
- */
- pullToRefresh.setMode(Mode.BOTH);
- init();
- /*
- * setOnRefreshListener(OnRefreshListener listener):设置刷新监听器;
- * setOnLastItemVisibleListener(OnLastItemVisibleListener listener):设置是否到底部监听器;
- * setOnPullEventListener(OnPullEventListener listener);设置事件监听器;
- * onRefreshComplete():设置刷新完成
- */
- /*
- * pulltorefresh.setOnScrollListener()
- */
- // SCROLL_STATE_TOUCH_SCROLL(1) 正在滚动
- // SCROLL_STATE_FLING(2) 手指做了抛的动作(手指离开屏幕前,用力滑了一下)
- // SCROLL_STATE_IDLE(0) 停止滚动
- /*
- * setOnLastItemVisibleListener
- * 当用户拉到底时调用
- */
- /*
- * setOnTouchListener是监控从点下鼠标 (可能拖动鼠标)到放开鼠标(鼠标可以换成手指)的整个过程 ,他的回调函数是onTouchEvent(MotionEvent event),
- * 然后通过判断event.getAction()是MotionEvent.ACTION_UP还是ACTION_DOWN还是ACTION_MOVE分别作不同行为。
- * setOnClickListener的监控时间只监控到手指ACTION_DOWN时发生的行为
- */
- pullToRefresh.setOnRefreshListener(new OnRefreshListener2<ListView>(){
- @Override
- public void onPullDownToRefresh(
- PullToRefreshBase<ListView> refreshView) {
- // TODO Auto-generated method stub
- PullBean bean = new PullBean();
- bean.setTitle("下拉刷新");
- bean.setContent("我的神");
- adapter.addFirst(bean);
- new FinishRefresh().execute();
- adapter.notifyDataSetChanged();
- }
- @Override
- public void onPullUpToRefresh(
- PullToRefreshBase<ListView> refreshView) {
- // TODO Auto-generated method stub
- PullBean bean = new PullBean();
- bean.setTitle("上拉刷新");
- bean.setContent("我的神");
- adapter.addLast(bean);
- new FinishRefresh().execute();
- adapter.notifyDataSetChanged();
- }
- });
- // pullToRefresh.setOnRefreshListener(new OnRefreshListener<ListView>() {
- //
- // @Override
- // public void onRefresh(PullToRefreshBase<ListView> refreshView) {
- // // TODO Auto-generated method stub
- // String label = DateUtils.formatDateTime(getApplicationContext(), System.currentTimeMillis(),
- // DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_ALL);
- //
- // // Update the LastUpdatedLabel
- // refreshView.getLoadingLayoutProxy().setLastUpdatedLabel(label);
- // PullBean bean = new PullBean();
- // bean.setTitle("我的神");
- // bean.setContent("我的神");
- // adapter.addFirst(bean);
- // new FinishRefresh().execute();
- // }
- //
- // });
- }
- private void init()
- {
- ILoadingLayout startLabels = pullToRefresh
- .getLoadingLayoutProxy(true, false);
- startLabels.setPullLabel("下拉刷新...");// 刚下拉时,显示的提示
- startLabels.setRefreshingLabel("正在载入...");// 刷新时
- startLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
- ILoadingLayout endLabels = pullToRefresh.getLoadingLayoutProxy(
- false, true);
- endLabels.setPullLabel("上拉刷新...");// 刚下拉时,显示的提示
- endLabels.setRefreshingLabel("正在载入...");// 刷新时
- endLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
- // // 设置下拉刷新文本
- // pullToRefresh.getLoadingLayoutProxy(false, true)
- // .setPullLabel("上拉刷新...");
- // pullToRefresh.getLoadingLayoutProxy(false, true).setReleaseLabel(
- // "放开刷新...");
- // pullToRefresh.getLoadingLayoutProxy(false, true).setRefreshingLabel(
- // "正在加载...");
- // // 设置上拉刷新文本
- // pullToRefresh.getLoadingLayoutProxy(true, false)
- // .setPullLabel("下拉刷新...");
- // pullToRefresh.getLoadingLayoutProxy(true, false).setReleaseLabel(
- // "放开刷新...");
- // pullToRefresh.getLoadingLayoutProxy(true, false).setRefreshingLabel(
- // "正在加载...");
- }
- private List<PullBean> getData(){
- List<PullBean> list = new ArrayList<PullBean>();
- for(int i = 0;i < 10;i ++){
- PullBean bean = new PullBean();
- bean.setTitle("item " + i + " 搜索业务增速下滑 Google廉颇老矣?");
- bean.setContent("Google于10月17日发布了2014年第三季度财报");
- list.add(bean);
- }
- return list;
- }
- private class FinishRefresh extends AsyncTask<Void, Void, Void>{
- @Override
- protected Void doInBackground(Void... params) {
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- }
- return null;
- }
- @Override
- protected void onPostExecute(Void result){
- // adapter.notifyDataSetChanged();
- pullToRefresh.onRefreshComplete();
- }
- }
- private class MyAdapter extends BaseAdapter{
- private LayoutInflater mInflater;
- public MyAdapter(Context context) {
- // TODO Auto-generated constructor stub
- mInflater = LayoutInflater.from(context);
- }
- public void addFirst(PullBean bean){
- data.add(0, bean);
- }
- public void addLast(PullBean bean){
- data.add(bean);
- }
- @Override
- public int getCount() {
- // TODO Auto-generated method stub
- return data.size();
- }
- @Override
- public Object getItem(int position) {
- // TODO Auto-generated method stub
- return data.get(position);
- }
- @Override
- public long getItemId(int position) {
- // TODO Auto-generated method stub
- return 0;
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- // TODO Auto-generated method stub
- ViewHolder viewHolder = null;
- if(convertView == null){
- viewHolder = new ViewHolder();
- convertView = mInflater.inflate(R.layout.item, null);
- viewHolder.title = (TextView) convertView.findViewById(R.id.title);
- viewHolder.content = (TextView) convertView.findViewById(R.id.content);
- convertView.setTag(viewHolder);
- }else{
- viewHolder = (ViewHolder) convertView.getTag();
- }
- viewHolder.title.setText(data.get(position).getTitle());
- viewHolder.content.setText(data.get(position).getContent());
- return convertView;
- }
- class ViewHolder{
- TextView title;
- TextView content;
- }
- }
- }
pullToRefresh适配器Adapter和listview也是继承于BaseAdapter 看一下item的布局
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:padding="5dp"
- android:orientation="vertical" >
- <TextView
- android:id="@+id/title"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:textSize="18sp"
- android:textColor="#BA55D3"
- android:text="我的神"/>
- <TextView
- android:id="@+id/content"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:textSize="14.0sp"
- android:layout_marginTop="5dp"
- android:textColor="#7CFC00"
- android:text="我的神"/>
- </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>
当然如果想自己设置上拉下拉中的文字 可以这样
- ILoadingLayout startLabels = pullToRefresh
- .getLoadingLayoutProxy(true, false);
- startLabels.setPullLabel("下拉刷新...");// 刚下拉时,显示的提示
- startLabels.setRefreshingLabel("正在载入...");// 刷新时
- startLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
- ILoadingLayout endLabels = pullToRefresh.getLoadingLayoutProxy(
- false, true);
- endLabels.setPullLabel("上拉刷新...");// 刚下拉时,显示的提示
- endLabels.setRefreshingLabel("正在载入...");// 刷新时
- endLabels.setReleaseLabel("放开刷新...");// 下来达到一定距离时,显示的提示
当然也可以这样
- pullToRefresh.getLoadingLayoutProxy(false, true)
- .setPullLabel("上拉刷新...");
- pullToRefresh.getLoadingLayoutProxy(false, true).setReleaseLabel(
- "放开刷新...");
- pullToRefresh.getLoadingLayoutProxy(false, true).setRefreshingLabel(
- "正在加载...");
- // 设置上拉刷新文本
- pullToRefresh.getLoadingLayoutProxy(true, false)
- .setPullLabel("下拉刷新...");
- pullToRefresh.getLoadingLayoutProxy(true, false).setReleaseLabel(
- "放开刷新...");
- pullToRefresh.getLoadingLayoutProxy(true, false).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
参考博客:
http://blog.csdn.net/lmj623565791/article/details/38238749
http://blog.csdn.net/harvic880925/article/details/17680305
谢谢原作者
PullToRefreshListView 应用讲解的更多相关文章
- PHP与API讲解(一)
了解API: 在使用与创建自己的API之前我们需要先了解什么是API! API代表应用程序编程接口,而接口指的是一个特定的服务.一个应用程序或者其他程序的公共模块. 理解SOA(面向服务的架构):SO ...
- 微信小程序(微信应用号)组件讲解
这篇文章主要讲解微信小程序的组件. 首先,讲解新建项目.现在有句话:招聘三天以上微信小程序开发,这个估计只能去挖微信的工程师了.技术新,既然讲解,那我们就从开始建项目讲解. 打开微信web开发者工具, ...
- 免费公开课,讲解强大的文档集成组件Aspose,现在可报名
课程①:Aspose.Total公开课内容:讲解全能型文档管理工具Aspose.Total主要功能及应用领域时间:2016-11-24 14:30 (暂定)报名地址:http://training.e ...
- EventBus总线讲解
在我们公司经常用到总线,具体的总线是什么让我理解我也不清楚,但是在这几个月下来,我已经知道总线如何使用,现在加上示例讲解总线如何使用. 1. 首先我们的新建一个类,这个类其实是用于总线传递的模型 us ...
- FTP的搭建与虚拟目录作用<之简单讲解>
操作系统:win7 VS2010编写WebService与在IIS的发布<之简单讲解>中我已经说了IIS安装与使用,不明白的可以跳过去看. 1.添加FTP站点 2. 3. 4. 5. zq ...
- Restful 介绍及SpringMVC+restful 实例讲解
restful不是一个框架,称为一种编码更烦更贴切吧,其核心类位于spring-web.jar中,即RestTemplate.class restful是rpc通过http协议的一种实现方式,和web ...
- 实例讲解react+react-router+redux
前言 总括: 本文采用react+redux+react-router+less+es6+webpack,以实现一个简易备忘录(todolist)为例尽可能全面的讲述使用react全家桶实现一个完整应 ...
- 【Spring】SpringMVC入门示例讲解
目录结构: // contents structure [-] SpringMVC是什么 Spring MVC的设计原理 SpringMVC入门示例 1,复制Jar包 2,Web.xml文件 3,My ...
- 十种MYSQL显错注入原理讲解(二)
上一篇讲过,三种MYSQL显错注入原理.下面我继续讲解. 1.geometrycollection() and geometrycollection((select * from(select * f ...
随机推荐
- Microsoft.mshtml.dll 添加引用及类型选择错误问题解决办法
在比较早的文章中,提到使用 Microsoft.mshtml.dll 进行模拟浏览器点击的例子. 1.添加引用的问题 一般在开发环境下会在三个地方存有microsoft.mshtml.dll文件.所以 ...
- 移动端web禁止长按选择文字以及弹出菜单
/*如果是禁用长按选择文字功能,用css*/ * { -webkit-touch-callout:none; -webkit-user-select:none; -khtml-user-select: ...
- SharePoint 2019 图文安装教程
前言 SharePoint 2019刚刚发布,很多群友在寻找安装教程,霖雨正好也下载了进行体验,就把完整的安装过程做成图文教程,分享给大家了,有需要的人可以有个参考. 文章从创建虚拟机开始,可能有点啰 ...
- C++ stringstream 简化数据类型转换
C++标准库中的<sstream>提供了比ANSI C的<stdio.h>更高级的一些功能,即单纯性.类型安全和可扩展性. 在C++中经常会使用到snprintf来格式化一些输 ...
- 【ZH奶酪】如何用textgenrnn处理中文
如何用textgenrnn处理中文 1. 什么是textgenrnn? textgenrnn是建立在Keras和TensorFlow之上的,可用于生成字级别和词级别文本.网络体系结构使用注意力加权来加 ...
- 自建Kubernetes logtail日志采集客户端安装方式
自建Kubernetes安装方式 前提条件 Kubernetes集群版本1.8及以上. 已经安装Helm命令,版本2.6.4及以上. 安装步骤 在日志服务控制台创建一个Project,Project名 ...
- C#中回滚TransactionScope的使用方法和原理
TransactionScope只要一个操作失败,它会自动回滚,Complete表示事务完成 实事上,一个错误的理解就是Complete()方法是提交事务的,这是错误的,事实上,它的作用的表示本事 ...
- 12C -- ORA-01033: ORACLE initialization or shutdown in progress
初装oracle 12.2 rac数据库. 登录RAC数据库中第1节点 $ sqlplus '/as sysdba' SQL> select name,open_mode from v$pdbs ...
- 9.12 翻译系列:数据注解特性之ConcurrencyCheck【EF 6 Code-First系列】
原文链接:https://www.entityframeworktutorial.net/code-first/concurrencycheck-dataannotations-attribute-i ...
- 关于MYSQL ERROR1045 报错的解决办法
**问题描述 **ERROR 1045 (28000): Access denied for user ‘root’@’localhost’ (using password: YES)或者ERROR ...