登录 立即注册
金钱:

Code4App-iOS开发-iOS 开源代码库-iOS代码实例搜索-iOS特效示例-iOS代码例子下载-Code4App.com

9种自由选择动画样式的第三方上下拉刷新库

[复制链接]
来自: 910157755 分类: iOS精品源码 上传时间: 2018-1-11 11:48:05
Tag:

项目介绍:

GitHub license
platform
language
Email

概述

高度可扩展、自定义、多样式的刷新框架。

比较

EGOTableViewPullRefresh SVPullToRefresh MJRefresh KafkaRefresh
多种样式选择 <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="20px" src="Assets/support.png"></img> <img width="20px" height="20px" src="Assets/support.png"></img>
刷新中允许交互 <img width="20px" height="20px" src="Assets/bug.png"> <img width="20px" height="20px" src="Assets/bug.png"> <img width="20px" height="23px" src="Assets/bug.png"></img> <img width="20px" height="20px" src="Assets/support.png"></img>
持续维护 <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="20px" src="Assets/support.png"></img> <img width="20px" height="20px" src="Assets/support.png"></img>
进度回调 <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="23px" src="Assets/unsupport.png"></img> <img width="20px" height="20px" src="Assets/support.png"></img>

特点

特点 描述
支持多样式选择与自定义 KafkaRefresh内置多种刷新样式,且可对样式进行自定义。扩展接口可让开发者集成更多丰富的UI效果。
非刷新状态自动隐藏 能避免开发者手动调整contentInset后刷新控件的出现而影响视觉体验;最常见的情况时,不存在数据时,底部的刷新的控件未隐藏,使用KafkaRefresh能避免该问题。
刷新结束时滑动抗抖动 当控件结束刷新,UIScrollView如果处于滑动状态,KafkaRefresh将根据刷新控件此时是否显示控制UIScrollView的contntOffset
支持抗内容偏移的滚动刷新 当用户滑动列表时,KafkaRefresh不会擅自调整列表的cntentOffset,KafkaRefresh不管处于何种刷新状态,都不会过多的调整列表位置。因此,您的列表集成KafkaRefresh后,滑动依旧是预期效果
支持设置触发刷新的偏移阀值 偏移阀值可自定义,自我把控触发刷新的条件;偏移阀值是基于控件高度的倍数,且必须大于1.0;否则无效。
支持全局配置 KafkaRefreshDefaults支持全局设置样式
支持进度回调 实时回调拖拽的偏移比例,对于扩展接口,可根据进度调整动画
自适应contentInset系统调整与手动调整 自适应iOS7以后UINavigationController自动调整scrollview contentOffset,KafkaRefresh也对iOS 11进行了适配;当您手动设置了contentInset的值,也无需担心KafkaRefresh会影响到视觉效果。
解决刷新状态分组视图悬停问题 当UITableView优多个分组,且分组视图的高度非0时,刷新状态将出现半空悬停的效果。从EGO以来,尝试解决该问题的刷新框架始于MJRefresh,但可惜的是,MJRefresh并未完美解决该问题(本质是因为contentOffset并非连续变化)。KafkaRefresh即使在刷新状态快速滑动,也能避开该问题的出现。
文档覆盖率100% 可在头文件中查看所有方法和类的使用
支持横竖屏切换自适应 无需在横竖屏切换时考虑刷新问题
iOS 7+ 支持iOS 7以上系统。包括iPhone X

安装

  • CocoaPods

pod 'KafkaRefresh'
  • Carthage

如果您想通过carthage安装 , 请您申请一个pull request.

使用

1.引入头文件
 #import "KafkaRefresh.h" 
2.初始化控件
  • 方式一

 [self.tableView bindRefreshStyle:KafkaRefreshStyleAnimatableArrow
                           fillColor:MainColor
                          atPosition:KafkaRefreshPositionHeader refreshHanler:^{
         //.......
    }];

 [self.tableView bindRefreshStyle:KafkaRefreshStyleAnimatableArrow
                           fillColor:MinorColor
                          atPosition:KafkaRefreshPositionFooter
                       refreshHanler:^{
         //.....
    }];
  • 方式二

 KafkaArrowHeader * arrow = [[KafkaArrowHeader alloc] init];
 arrow.refreshHandler = ^{
     //.....
 };
 self.tableView.headRefreshControl = arrow;
  • 方式三 全局配置

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    [[KafkaRefreshDefaults standardRefreshDefaults] setHeaderDefaultStyle:KafkaRefreshStyleAnimatableRing];
    return YES;
}

[self.tableView bindDefaultRefreshStyleAtPosition:KafkaRefreshPositionHeader refreshHanler:^{
        //.....
}];
3.手动触发刷新
 [self.tableView.headRefreshControl beginRefreshing];

 [self.tableView.footRefreshControl beginRefreshing];
4.结束刷新
 [self.tableView.headRefreshControl endRefreshing];

 [self.tableView.footRefreshControl endRefreshing];

自定义

以KafkaheadRefreshControl为例:

 #import "KafkaheadRefreshControl.h"
 @interface CustomHeader : KafkafootRefreshControl
 @end

*
.m

@implementation CustomHeader 

- (void)setupProperties{
   [super setupProperties];
   //初始化属性
}

- (void)kafkaDidScrollWithProgress:(CGFloat)progress max:(const CGFloat)max{
   //进度回调
}

- (void)kafkaRefreshStateDidChange:(KafkaRefreshState)state{
   [super kafkaRefreshStateDidChange:state];
   
   switch (state) {
       case KafkaRefreshStateNone:{
           break;
       }
       case KafkaRefreshStateScrolling:{
           break;
       }
       case KafkaRefreshStateReady:{
           break;
       }
       case KafkaRefreshStateRefreshing:{ 
           break;
       }
       case KafkaRefreshStateWillEndRefresh:{ 
           break;
       }
   }
}
@end

交流

  1. 如需要帮助,请邮件 <xorshine@icloud.com>或者wechat:Xiangxh1015;

  2. 如遇到bug,请在Github open an issue,烦请您提供重现步骤;

  3. 个人精力有限,Kafka提供的回调接口足够去增加更丰富的UI效果,很欢迎您一起参与,并提交pull request;

  4. 如果您对该库有更好的设计思路,请务必e-mail或wechat。

License

KafkaRefresh采用MIT开源协议。

相关源码推荐:

我来说两句
*滑动验证:
所有评论(97)
AlonMessi 2018-1-11 15:06:09
写的真的很不错
回复
phoiu 2018-1-11 15:06:27
code4app好的内容真的很多~赞
回复
littleRed 2018-1-11 15:06:43
感谢分享,code4app有你更精彩
回复
hellokenken 2018-1-11 15:07:26
内容很好,棒棒哒
回复
BlueManlove 2018-1-11 15:07:40
不错不错,楼主辛苦了。。。
回复
kengsir 2018-1-11 15:07:51
相当不错,感谢无私分享精神!
回复
wx_l713G6W7 2018-1-11 15:10:50
很给力,Code4App有你更精彩!
回复
code4app热心网友 2018-1-11 15:14:26
精华内容,楼主V5!
回复
code4app热心网友 2018-1-11 15:23:53
学习学习!
回复
提取码:  下载次数:101 状态:已购或VIP 售价:0(原价:15)金钱 下载权限:初级码农 
1818 2 101
联系我们
首页/微信公众账号投稿

帖子代码编辑/版权问题

QQ:435399051,742864542

如何获得代码达人称号?

代码贡献英雄榜
用户名 下载数
通过邮件订阅最新 Code4App 信息
上一条 /4 下一条
联系我们
关闭
合作电话:
13802416937
Email:
435399051@qq.com
商务市场合作/投稿
问题反馈及帮助
联系我们

广告投放| Github|申请友链|手机版|Code4App ( 粤ICP备15117877号-1 )

快速回复 返回顶部 返回列表