You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

115 lines
3.0 KiB

//
// XHRefreshControl.h
// MessageDisplayExample
//
// Created by 曾 宪华 on 14-6-6.
// Copyright (c) 2014年 曾宪华 开发团队(http://iyilunba.com ) 本人QQ:543413507 本人QQ群(142557668). All rights reserved.
//
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
// 需要大量的delegate用于外部做定制
// 必须实现的delegate
// 1、是否加载中
// 2、将要开始下拉刷新的方法
// 3、将要开始上提加载更多的方法
// 4、最后更新数据的时间
// 可选实现的delegate
// 1、是否支持下拉刷新
// 2、是否支持上提加载更多
// 3、标识下拉刷新是UIScrollView的子view,还是UIScrollView父view的子view
// 4、是否保留iOS7的新特性,只对滚动视图有效
// 5、多少次上提加载后,启用点击按钮进行加载一页数据
typedef NS_ENUM(NSInteger, XHRefreshViewLayerType) {
XHRefreshViewLayerTypeOnScrollViews = 0,
XHRefreshViewLayerTypeOnSuperView = 1,
};
@protocol XHRefreshControlDelegate <NSObject>
@required
/**
* 1、这个是用于标识用户是否在加载数据中,所以涉及到业务逻辑的问题,所以就外部传值
*
* @return 如果不实现该delegate方法,所以效果都会实现
*/
- (BOOL)isLoading;
/**
* 2、将要开始下拉刷新的方法
*/
- (void)beginPullDownRefreshing;
/**
* 3、将要开始上提加载更多的方法
*/
- (void)beginLoadMoreRefreshing;
/**
* 4、最后更新数据的时间
*
* @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、UIScrollView的控制器是否保留iOS7新的特性,意思是:tablView的内容是否可以穿透过导航条
*
* @return 如果不是先该delegate方法,默认是不支持的
*/
- (BOOL)keepiOS7NewApiCharacter;
/**
* 5、将自动加载更多的状态转换为手动加载需要的条件,现在是加载更多多少次后,开始转换
*
* @return 如果不实现该delegate方法,默认是5次
*/
- (NSInteger)autoLoadMoreRefreshedCountConverManual;
@end
@interface XHRefreshControl : NSObject
- (id)initWithScrollView:(UIScrollView *)scrollView delegate:(id <XHRefreshControlDelegate>)delegate;
/**
* 外部手动启动下拉加载的方法,这个方法不需要手动去拖动UIScrollView
*/
- (void)startPullDownRefreshing;
/**
* 停止下拉刷新的方法
*/
- (void)endPullDownRefreshing;
/**
* 停止上提加载更多的方法
*/
- (void)endLoadMoreRefresing;
@end