# XZMRefresh **Repository Path**: zhongminCoder/XZMRefresh ## Basic Information - **Project Name**: XZMRefresh - **Description**: The easiest way to use pull-to-The transverse refresh(非常易用的横向刷新框架与MJRefresh用法一致) - **Primary Language**: Objective-C - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 2 - **Forks**: 0 - **Created**: 2016-01-29 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # XZMRefresh The easiest way to use pull-to-The transverse refresh(非常易用的横向刷新框架与MJRefresh用法一致) #框架开发的缘由: ## 现今已有越来越多的APP需要横向刷新的需求,然而MJRefresh已不能满足该需求,这套框架已经使用的非常的广泛,并且框架本身封装比较完美集成使用也非常的简单,方法的使用大家也非常的熟悉,所以XZMRefresh本着模仿MJRefresh框架做了横向刷新的Refresh,这样大家不必再去适应繁琐的新框架集成。 ##APP实例 ###1.好赞APP ![(好赞刷新)](http://7xkt3g.com1.z0.glb.clouddn.com/refreshrefresh_haozang2.gif) ###2.淘宝APP ![(淘宝刷新)](http://7xkt3g.com1.z0.glb.clouddn.com/refreshrefresh_taobao.gif) ## Content * 使用方法参考 * [默认](#默认) * [隐藏时间](#隐藏时间) * [动画图片](#动画图片) * [动画图片 + 隐藏状态和时间](#动画图片 + 隐藏状态和时间) * [自定义文字](#自定义文字) * [特性说明](#特性说明) ## 如何使用XZMRefresh * cocoapods导入:`pod 'XZMRefresh'` * 手动导入: * 将`XZMRefresh`文件夹中的所有文件拽入项目中 * 导入主头文件:`#import "XZMRefresh.h"` - 下拉刷新控件的种类 - 默认(Normal):`XZMRefreshNormalHeader` - 动图(Gif):`XZMRefreshGifHeader` - 上拉刷新控件的种类 - 默认(Normal):`XZMRefreshNormalFooter` - 动图(Gif):`XZMRefreshGifFooter` ## 默认 ```objc #pragma mark UICollectionView + 默认刷新 - (void)addNormalHeader { __weak typeof(self) weakself = self; // 添加下拉刷新头部控件 [self.collectionView addNormalHeaderWithCallback:^{ // 增加1条假数据 weakself.examples += 1; // 模拟延迟加载数据,因此2秒后才调用) dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ [weakself.collectionView reloadData]; // 结束刷新 [weakself.collectionView.xzm_header endRefreshing]; }); }]; // 自动刷新(一进入程序就下拉刷新) [self.collectionView.xzm_header beginRefreshing]; } ``` ![(默认刷新)](http://7xkt3g.com1.z0.glb.clouddn.com/Refreshrefresh_moren.gif) ## 隐藏时间 ```objc // 隐藏时间 self.collectionView.xzm_header.updatedTimeHidden = YES; ``` ![(隐藏时间)](http://7xkt3g.com1.z0.glb.clouddn.com/Refreshrefresh_hide_date.gif) ## 动画图片 ```objc __weak typeof(self) weakself = self; // 添加下拉刷新头部控件 [self.collectionView addGifHeaderWithCallback:^{ // 进入刷新状态就会回调这个Block // 增加1条假数据 weakself.examples += 1; // 模拟延迟加载数据,因此2秒后才调用) dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ [weakself.collectionView reloadData]; // 结束刷新 [weakself.collectionView.xzm_gifHeader endRefreshing]; }); }]; // 设置普通状态的动画图片 NSMutableArray *idleImages = [NSMutableArray array]; for (NSUInteger i = 1; i<=60; i++) { UIImage *image = [UIImage imageNamed:[NSString stringWithFormat:@"dropdown_anim__000%zd", i]]; [idleImages addObject:image]; } [self.collectionView.xzm_gifHeader setImages:idleImages forState:XZMRefreshStateNormal]; // 设置正在刷新状态的动画图片 NSMutableArray *refreshingImages = [NSMutableArray array]; for (NSUInteger i = 1; i<=3; i++) { UIImage *image = [UIImage imageNamed:[NSString stringWithFormat:@"dropdown_loading_0%zd", i]]; [refreshingImages addObject:image]; } [self.collectionView.xzm_gifHeader setImages:refreshingImages forState:XZMRefreshStateRefreshing]; // 马上进入刷新状态 [self.collectionView.xzm_gifHeader beginRefreshing]; ``` ![(动画图片)](http://7xkt3g.com1.z0.glb.clouddn.com/Refreshrefresh_donghua.gif) ## 动画图片 + 隐藏状态和时间 ```objc // 添加动画图片代码同上 // 隐藏时间 self.collectionView.xzm_gifHeader.updatedTimeHidden = YES; // 隐藏状态 self.collectionView.xzm_gifHeader.stateHidden = YES; ``` ![(动画图片 + 隐藏状态和时间)](http://7xkt3g.com1.z0.glb.clouddn.com/Refreshrefresh_donghua_hide.gif) ## 自定义文字 ```objc // 设置文字 [self.collectionView.xzm_header setTitle:@"滑动可以刷新" forState:XZMRefreshStateNormal]; [self.collectionView.xzm_header setTitle:@"释放立即刷新" forState:XZMRefreshStatePulling]; [self.collectionView.xzm_header setTitle:@"正在刷新中 ..." forState:XZMRefreshStateRefreshing]; // 设置字体 self.collectionView.xzm_header.font = [UIFont systemFontOfSize:15]; // 设置颜色 self.collectionView.xzm_header.textColor = [UIColor redColor]; ``` ![(自定义文字)](http://7xkt3g.com1.z0.glb.clouddn.com/Refreshrefresh_text.gif) ## 特性说明 * 本框架纯ARC,兼容的系统>=iOS6.0 * 如果在使用过程中遇到BUG,希望你能与我联系(我的邮箱:364101515qq.com) * 如果有好的建议以及框架上的不足,请联系我,非常感谢你! * 如果喜欢你就Star一下吧,感谢你的支持!