下拉刷新 SVPullToRefresh 的使用及两个比较优秀的第三方下拉刷新

一.下载第三方库

https://github.com/samvermette/SVPullToRefresh

二.使用方法

1.导入下载的第三方库

2.导入头文件

在需要的类里导入这一个头文件就能,同时使用下拉刷新,上拉加载

#import "SVPullToRefresh.h"

3.下拉刷新

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
现在第三方下拉刷新的库非常多,但是比较常用的就是PullToRefresh了,因为支持的控件比较多 但是缺点就是代码量很大 原生可定制性比较差,所以花了一些时间研究了下这个库。 话不多说,说干就干。我们先集成PullToRefresh到自己的项目中。集成后项目的结构 集成完库,开始写一个简单的ListView看一下默认的效果。 1、PullToRefreshListView快速创建,看效果 MainActivity布局文件 控件初始化和加载适配器 模拟联网,两秒后设置加载完成 Adapter就是基础listView写法就不贴代码了和item自己随便写个简单的布局就好,接下来就可以看效果了。 看到这个上拉和下拉的效果,估计好多小伙伴的需求并不是要这个效果,都会要加一些自己的文字或者动画。下面我们就开始简单的定制这个上拉和下拉的布局 2、文字定制 修改文字比较简单,控件已经提供了相应的方法,直接上代码 紧紧文字的修改是远远不够的,我还要修改动画怎么办呢?下面就是引入动画 3、动画定制 接下来的定制都是需要去库里面修改代码了,可要打起精神,防止出错。 在PullTorefreshBase这个类中扎到 方法;修改以下 //此处实现了我们需要 修改的动画方法: //修改代码实现 自己的下载刷新动画 LoadingLayout createLoadingLayout(Context context, Mode mode, Orientation scrollDirection, TypedArray attrs) { switch (this) { case ROTATE: default: //帧动画 frameAnimationLayout为 自定义动画类 //通过mode判断是header还是footer if (Mode.PULL_FROM_START == mode) { return new FrameAnimationLayout(context, mode, scrollDirection, attrs); } else if (Mode.PULL_FROM_END == mode) { return new RotateLoadingLayout(context, mode, scrollDirection, attrs); } // return new RotateLoadingLayout(context, mode, scrollDirection, attrs); case FLIP: return new FlipLoadingLayout(context, mode, scrollDirection, attrs); } } 重点就在通过mode参数判断是下拉还是上拉,我可以分别修改动画。但是我还想在控件中加入一些其他文字,这就需要修改Header布局文件,进入资源文件找到,问项目中用的是ListView,所以要修改vertical这个布局,具体修改就看你公司需求自己定制了。 这里要说的是重点!因为这个布局文件header和footer共用的,如果有控件要在代码中操作它的显示与隐藏,要在LoadingLayout类的构造器中初始化对象。 在下面几行代码中,还是通过mode这个参数判断是上拉还是下拉,来区分你的操作,来显示不同的头和脚。 接下来修复添加自己的控件后会有显示方面的bug, 需要在showInvisibleViews和hideAllViews两个方法中分别把需要操作的控件分别显示和隐藏,要不下拉或者上拉距离过 大会导致控件偶尔不隐藏的bug。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值