image XHRefreshControl
XHRefreshControl 是一款高扩展性、低耦合度的下拉刷新、上提加载更多的组件。
CocosPods is the recommended method to install XHRefreshControl, just add the following line to Podfile
pod 'XHRefreshControl'
and run pod install, then you're all done!
- 添加外部自定义下拉View和下拉状态-------已经完成
提供两种使用方式: 1、继承UIViewController,自定义TableView。 使用方法很简单 #import "XHPullRefreshTableViewController.h" 继承XHPullRefreshTableViewController, 提供以下多个方法处理加载数据的不同处理方法: /** * 是否支持下拉刷新 */ @property (nonatomic, assign) BOOL pullDownRefreshed; /** * 是否支持上拉刷新 */ @property (nonatomic, assign) BOOL loadMoreRefreshed; /** * 下拉刷新的样式 */ @property (nonatomic, assign) XHPullDownRefreshViewType refreshViewType; /** * 加载数据的页码 */ @property (nonatomic, assign) NSInteger requestCurrentPage; /** * 自动下拉刷新调用的方法,必须放在viewDidAppear方法内,别把这行代码放到别处,然后导致了错误,那就不好了嘛! */ - (void)startPullDownRefreshing; /** * 当下拉加载数据完成后,你必须调用该方法哦! */ - (void)endPullDownRefreshing; /** * 当上啦加载数据完成后,你也得调用该方法哦!然后你可能会问,那我要怎么判断是下拉还是上啦啊?requestCurrentPage看这个变量,会跟着变化哦! */ - (void)endLoadMoreRefreshing; /** * 当上啦加载数据回调告诉我们,已经没有下一页了,那你可以调用该方法,告诉用户你已经没有数据了哦! * * @param message 提示用户的信息 */ - (void)endMoreOverWithMessage:(NSString *)message; /** * 当网络加载失败的时候,你必须调用该方法,如果你不调用,我也帮不了你了 */ - (void)handleLoadMoreError; 2、直接使用UITableViewController,提供兼容下拉、上啦刷新的处理。 #import "XHSysatemRefreshTableViewController.h" 提供的内部方法和第一个方式是一样的! 你也可以自己定制一个属于你自己的控制器,至于你要加入其他基础类的方法,那就您好好定制了。以下提供这些方法给您定制下拉、上拉的样式。 #import "XHRefreshControl.h" XHRefreshControl *refreshControl = [[XHRefreshControl alloc] initWithScrollView:self.yourTableView delegate:self]; 以下手动可调用的方法 /** * 外部手动启动下拉加载的方法,这个方法不需要手动去拖动UIScrollView */ - (void)startPullDownRefreshing; /** * 停止下拉刷新的方法 */ - (void)endPullDownRefreshing; /** * 停止上提加载更多的方法 */ - (void)endLoadMoreRefresing; /** * 没有更多的数据加载 */ - (void)endMoreOverWithMessage:(NSString *)message; 以下是delegate方法,用于外部定制 implementation XHRefreshControl required delegate: @required /** * 1、将要开始下拉刷新的方法 */ - (void)beginPullDownRefreshing; /** * 2、将要开始上提加载更多的方法 */ - (void)beginLoadMoreRefreshing; /** * 3、最后更新数据的时间 * * @return 返回缓存最后更新某个页面的时间 */ - (NSDate *)lastUpdateTime; @optional /** * 1、是否支持下拉刷新 * * @return 如果没有实现该delegate方法,默认是支持下拉的,为YES */ - (BOOL)isPullDownRefreshed; /** * 2、是否支持上提加载更多 * * @return 如果没有实现该delegate方法,默认是支持上提加载更多的,为YES */ - (BOOL)isLoadMoreRefreshed; /** * 3、标识下拉刷新是UIScrollView的子view,还是UIScrollView父view的子view * * @return 如果没有实现该delegate方法,默认是scrollView的子View,为XHRefreshViewLayerTypeOnScrollViews */ - (XHRefreshViewLayerType)refreshViewLayerType; /** * 4、下拉刷新使用哪种样式 * * @return 如果没有实现该delegate方法,默认是网易新闻App的样式 */ - (XHPullDownRefreshViewType)pullDownRefreshViewType; /** * 4、UIScrollView的控制器是否保留iOS7新的特性,意思是:tablView的内容是否可以穿透过导航条 * * @return 如果不是先该delegate方法,默认是不支持的 */ - (BOOL)keepiOS7NewApiCharacter; /** * 5、将自动加载更多的状态转换为手动加载需要的条件,现在是加载更多多少次后,开始转换 * * @return 如果不实现该delegate方法,默认是5次 */ - (NSInteger)autoLoadMoreRefreshedCountConverManual; /** * 6、获取用户定义下拉的View * * @return 返回用户定义的View */ - (UIView *)customPullDownRefreshView; /** * 7、通知外部,下拉的距离,用于定制某个时机的状态 * * @param refreshView 需要改变状态的View * @param pullDownOffset 下拉的距离 */ - (void)customPullDownRefreshView:(UIView *)customPullDownRefreshView withPullDownOffset:(CGFloat)pullDownOffset; /** * 8、将要下拉的时候,被调用 * * @param customPullDownRefreshView 目标下拉的View */ - (void)customPullDownRefreshViewWillStartRefresh:(UIView *)customPullDownRefreshView; /** * 9、将要停止下啦的时候,被调用 * * @param customPullDownRefreshView 目标下啦的View */ - (void)customPullDownRefreshViewWillEndRefresh:(UIView *)customPullDownRefreshView;
中文: XHRefreshControl 是在MIT协议下使用的,可以在LICENSE文件里面找到相关的使用协议信息。
English: XHRefreshControl is available under the MIT license, see the LICENSE file for more information.
如果您在您的项目中使用该开源组件,请给我们发电子邮件告诉我们您的应用程序的名称,谢谢!主要是为了互推的效果,如果您的app火了,请给予少许的回报,如果您的App不火,或许能通过这个开源库了解到您的App!
If you use this open source components in your project, please Email us to notify us the name of your application(s). Thanks!