当前位置:   article > 正文

iOS常用下拉刷新上拉加载库MJRefresh使用说明_triggerautomaticallyrefreshpercent

triggerautomaticallyrefreshpercent

简介

项目主页地址:MJRefresh

项目下载地址:点击下载

适用范围:可用于常见控件 UIScrollViewUITableViewUICollectionViewUIWebView 实现上拉刷新和下拉加载的效果。

  • ARC
  • iOS>=6.0
  • iPhone \ iPad screen anyway

加入项目方式:

CocoaPods安装:pod 'MJRefresh'

手动加入:将MJRefresh文件夹下所有文件拖入项目,使用时候 #import "MJRefresh.h"即可。

 

文件结构:

废话不多说,看常用接口代码:

MJRefreshComponent.h

  1. /** 刷新控件的基类 */
  2. @interface MJRefreshComponent : UIView
  3. #pragma mark - 刷新状态控制
  4. /** 进入刷新状态 */
  5. - (void)beginRefreshing;
  6. /** 结束刷新状态 */
  7. - (void)endRefreshing;
  8. /** 是否正在刷新 */
  9. - (BOOL)isRefreshing;
  10. #pragma mark - 其他
  11. /** 根据拖拽比例自动切换透明度 */
  12. @property (assign, nonatomic, getter=isAutomaticallyChangeAlpha) BOOL automaticallyChangeAlpha;
  13. @end

MJRefreshHeader.h

  1. // 下拉刷新控件:负责监控用户下拉的状态
  2. @interface MJRefreshHeader : MJRefreshComponent
  3. /** 创建header */
  4. + (instancetype)headerWithRefreshingBlock:(MJRefreshComponentRefreshingBlock)refreshingBlock;
  5. /** 创建header */
  6. + (instancetype)headerWithRefreshingTarget:(id)target refreshingAction:(SEL)action;
  7. /** 这个key用来存储上一次下拉刷新成功的时间 */
  8. @property (copy, nonatomic) NSString *lastUpdatedTimeKey;
  9. /** 上一次下拉刷新成功的时间 */
  10. @property (strong, nonatomic, readonly) NSDate *lastUpdatedTime;
  11. /** 忽略多少scrollView的contentInset的top */
  12. @property (assign, nonatomic) CGFloat ignoredScrollViewContentInsetTop;
  13. @end

MJRefreshFooter.h

  1. // 上拉刷新控件
  2. @interface MJRefreshFooter : MJRefreshComponent
  3. /** 创建footer */
  4. + (instancetype)footerWithRefreshingBlock:(MJRefreshComponentRefreshingBlock)refreshingBlock;
  5. /** 创建footer */
  6. + (instancetype)footerWithRefreshingTarget:(id)target refreshingAction:(SEL)action;
  7. /** 提示没有更多的数据 */
  8. - (void)endRefreshingWithNoMoreData;
  9. - (void)noticeNoMoreData MJRefreshDeprecated("使用endRefreshingWithNoMoreData");
  10. /** 重置没有更多的数据(消除没有更多数据的状态) */
  11. - (void)resetNoMoreData;
  12. /** 忽略多少scrollView的contentInset的bottom */
  13. @property (assign, nonatomic) CGFloat ignoredScrollViewContentInsetBottom;
  14. /** 自动根据有无数据来显示和隐藏(有数据就显示,没有数据隐藏。默认是NO*/
  15. @property (assign, nonatomic, getter=isAutomaticallyHidden) BOOL automaticallyHidden MJRefreshDeprecated("不建议使用此属性,开发者请自行控制footer的显示和隐藏。基于安全考虑,在未来的某些版本此属性可能作废");
  16. @end

MJRefreshAutoFooter.h

  1. @interface MJRefreshAutoFooter : MJRefreshFooter
  2. /** 是否自动刷新(默认为YES) */
  3. @property (assign, nonatomic, getter=isAutomaticallyRefresh) BOOL automaticallyRefresh;
  4. /** 当底部控件出现多少时就自动刷新(默认为1.0,也就是底部控件完全出现时,才会自动刷新) */
  5. @property (assign, nonatomic) CGFloat appearencePercentTriggerAutoRefresh MJRefreshDeprecated("请使用triggerAutomaticallyRefreshPercent属性");
  6. /** 当底部控件出现多少时就自动刷新(默认为1.0,也就是底部控件完全出现时,才会自动刷新) */
  7. @property (assign, nonatomic) CGFloat triggerAutomaticallyRefreshPercent;
  8. /** 是否每一次拖拽只发一次请求 */
  9. @property (assign, nonatomic, getter=isOnlyRefreshPerDrag) BOOL onlyRefreshPerDrag;
  10. @end

开始示例:

下拉刷新

下拉刷新01-默认

  1. self.tableView.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
  2. // 进入刷新状态后会自动调用这个block
  3. }];
  4. // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadNewData方法)
  5. self.tableView.header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];
  6. // 马上进入刷新状态
  7. [self.tableView.header beginRefreshing];

下拉刷新02-动画图片

  1. // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadNewData方法)
  2. MJRefreshGifHeader *header = [MJRefreshGifHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];
  3. // 设置普通状态的动画图片
  4. [header setImages:idleImages forState:MJRefreshStateIdle];
  5. // 设置即将刷新状态的动画图片(一松开就会刷新的状态)
  6. [header setImages:pullingImages forState:MJRefreshStatePulling];
  7. // 设置正在刷新状态的动画图片
  8. [header setImages:refreshingImages forState:MJRefreshStateRefreshing];
  9. // 设置header
  10. self.tableView.header = header;

下拉刷新03-隐藏时间

  1. // 隐藏时间
  2. header.lastUpdatedTimeLabel.hidden = YES;

下拉刷新04-隐藏状态和时间

  1. // 隐藏时间
  2. header.lastUpdatedTimeLabel.hidden = YES;
  3. // 隐藏状态
  4. header.stateLabel.hidden = YES;

下拉刷新05-自定义文字

  1. // 设置文字
  2. [header setTitle:@"Pull down to refresh" forState:MJRefreshStateIdle];
  3. [header setTitle:@"Release to refresh" forState:MJRefreshStatePulling];
  4. [header setTitle:@"Loading ..." forState:MJRefreshStateRefreshing];
  5. // 设置字体
  6. header.stateLabel.font = [UIFont systemFontOfSize:15];
  7. header.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:14];
  8. // 设置颜色
  9. header.stateLabel.textColor = [UIColor redColor];
  10. header.lastUpdatedTimeLabel.textColor = [UIColor blueColor];

下拉刷新06-自定义刷新控件

  1. self.tableView.header = [MJDIYHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];
  2. // 具体实现参考MJDIYHeader.h和MJDIYHeader.m

上拉刷新

上拉刷新01-默认

  1. self.tableView.footer = [MJRefreshAutoNormalFooter footerWithRefreshingBlock:^{
  2. // 进入刷新状态后会自动调用这个block
  3. }];
  4. // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadMoreData方法)
  5. self.tableView.footer = [MJRefreshAutoNormalFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];

上拉刷新02-动画图片

  1. // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadMoreData方法)
  2. MJRefreshAutoGifFooter *footer = [MJRefreshAutoGifFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
  3. // 设置刷新图片
  4. [footer setImages:refreshingImages forState:MJRefreshStateRefreshing];
  5. // 设置尾部
  6. self.tableView.footer = footer;

上拉刷新03-隐藏刷新状态的文字

  1. // 隐藏刷新状态的文字
  2. footer.refreshingTitleHidden = YES;
  3. // 如果没有上面的方法,就用footer.stateLabel.hidden = YES;

上拉刷新04-全部加载完毕

  1. // 变为没有更多数据的状态
  2. [footer noticeNoMoreData];

上拉刷新05-自定义文字

  1. // 设置文字
  2. [footer setTitle:@"Click or drag up to refresh" forState:MJRefreshStateIdle];
  3. [footer setTitle:@"Loading more ..." forState:MJRefreshStateRefreshing];
  4. [footer setTitle:@"No more data" forState:MJRefreshStateNoMoreData];
  5. // 设置字体
  6. footer.stateLabel.font = [UIFont systemFontOfSize:17];
  7. // 设置颜色
  8. footer.stateLabel.textColor = [UIColor blueColor];

上拉刷新06-加载后隐藏

  1. // 隐藏当前的上拉刷新控件
  2. self.tableView.footer.hidden = YES;

上拉刷新07-自动回弹的上拉01

self.tableView.footer = [MJRefreshBackNormalFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];

上拉刷新08-自动回弹的上拉02

  1. MJRefreshBackGifFooter *footer = [MJRefreshBackGifFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
  2. // 设置普通状态的动画图片
  3. [footer setImages:idleImages forState:MJRefreshStateIdle];
  4. // 设置即将刷新状态的动画图片(一松开就会刷新的状态)
  5. [footer setImages:pullingImages forState:MJRefreshStatePulling];
  6. // 设置正在刷新状态的动画图片
  7. [footer setImages:refreshingImages forState:MJRefreshStateRefreshing];
  8. // 设置尾部
  9. self.tableView.footer = footer;

上拉刷新09-自定义刷新控件(自动刷新)

  1. self.tableView.footer = [MJDIYAutoFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
  2. // 具体实现参考MJDIYAutoFooter.h和MJDIYAutoFooter.m

上拉刷新10-自定义刷新控件(自动回弹)

  1. self.tableView.footer = [MJDIYBackFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
  2. // 具体实现参考MJDIYBackFooter.h和MJDIYBackFooter.m

UICollectionView01-上下拉刷新

  1. // 下拉刷新
  2. self.collectionView.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
  3. // 进入刷新状态后会自动调用这个block
  4. }];
  5. // 上拉刷新
  6. self.collectionView.footer = [MJRefreshAutoNormalFooter footerWithRefreshingBlock:^{
  7. // 进入刷新状态后会自动调用这个block
  8. }];

UIWebView01-下拉刷新

  1. // 添加下拉刷新控件
  2. self.webView.scrollView.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
  3. // 进入刷新状态后会自动调用这个block
  4. }];

 

参考:https://github.com/CoderMJLee/MJRefresh

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/229209
推荐阅读
相关标签
  

闽ICP备14008679号