iOS开发 ----- 下拉刷新
来源:互联网 发布:淘宝类目数据查询 编辑:程序博客网 时间:2024/05/16 13:43
下拉刷新
百度一下,基本上都是三方库,MJ的,EGO的等等,基本没有自己写的(估计是我姿势不对),所以就自己想写一个,其实也很简单,下边说下原理
1. UITableView是继承与UIScrollView的,所以可以检测滑动的状态
2. 可以在屏幕外边放一个view,然后滑动的时候,改变他的frame,让他跟着出来
3. 然后松手的时候,view移动到一个位置,tableView也定到一个位置,然后开始请求数据
4. 请求完数据之后,让view回去,tableView也回到原来的位置,然后重载数据
这就是基本的思路,不会画图,大家自己理解下吧,
这个方法会在tableView滚动的时候一直调用,所以,这里可以让view跟着tableView下拉出现,效果还是挺好的
-(void)scrollViewDidScroll:(UIScrollView *)scrollView
这个方法会在手指抬起的时候调用,这里可以让tableView和view定到一个合理的位置
-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
请求完数据之后,在恢复
思路就是这样,下边是代码,这里用到了AFnetWorking这个三方库,用来请求数据,接口是爱限免的,这里用了两个view,一个充当背景,一个用来显示文字,考虑到可扩展性,这样还是比较合理的,一个也是完全可以的,有一个背景的话,还可以加更多的东西
源代码在这里
这里是上拉加载
贴个图看看,帧数不够,看不出来,数据比较小,所以立马就出来了,动画可以自己修改,随便搞
#import "ViewController.h"#import "AFNetworking.h"@interface ViewController ()<UITableViewDataSource,UITableViewDelegate>//tableView@property(strong, nonatomic)UITableView * tableView;//刷新出来的View的总view@property(strong, nonatomic)UIView * refreshView;//上边的饿字体@property(strong, nonatomic)UILabel * refreshLabel;//当前页@property(assign, nonatomic)NSInteger page;//存放数据的数组@property(strong, nonatomic)NSMutableArray * dataArray;@end@implementation ViewController- (void)viewDidLoad { [super viewDidLoad]; //设置为第1页 _page = 1; //创建刷新view [self createRefreshView]; //创建tableView [self createTableView]; //创建数据 [self createData]; //初始化数组 _dataArray = [[NSMutableArray alloc]init];}//创建刷新的view,超出屏幕100点,先添加到屏幕上,然后在添加tableView-(void)createRefreshView{ _refreshView = [[UIView alloc]initWithFrame:CGRectMake(0, -100, 375, 100)]; _refreshView.backgroundColor = [UIColor whiteColor]; _refreshLabel = [[UILabel alloc]initWithFrame:CGRectMake(0, 0, 375, 100)]; _refreshLabel.text = @"下拉刷新"; _refreshLabel.font = [UIFont systemFontOfSize:30]; _refreshLabel.textColor = [UIColor redColor]; _refreshLabel.textAlignment = NSTextAlignmentCenter; [_refreshView addSubview:_refreshLabel]; [self.view addSubview:_refreshView];}//创建tableView-(void)createTableView{ _tableView = [[UITableView alloc]initWithFrame:[UIScreen mainScreen].bounds style:UITableViewStylePlain]; _tableView.dataSource = self; _tableView.delegate = self; [self.view addSubview:_tableView];}//创建数据,用到AFnetWorking,本来想用NSURLSession的,这个类貌似是由于线程的原因,要手从戳一下屏幕才可以显示数据//效果并不好,所以用了AFNetWorking//下边是解析数据,没什么好说的,-(void)createData{ NSString * path = [NSString stringWithFormat:@"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=%ld",_page]; AFHTTPRequestOperationManager * manager = [AFHTTPRequestOperationManager manager]; [manager GET:path parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) { //下拉刷新,总是要请求最新的数据,然后显示,所以,先清空数据,然后在添加 [_dataArray removeAllObjects]; NSArray * array = [responseObject objectForKey:@"applications"]; for (NSDictionary * temp in array) { [_dataArray addObject:[temp objectForKey:@"name"]]; } //修改偏移量,这个下边在加载的时候,修改了偏移量,这里改回来 [UIView animateWithDuration:0.2 animations:^{ _tableView.contentInset = UIEdgeInsetsMake(0, 0, 0, 0); } completion:^(BOOL finished) { //动画结束之后,修改label的文本显示 //然后重载数据 _refreshLabel.text = @"下拉刷新"; [_tableView reloadData]; }]; } failure:^(AFHTTPRequestOperation *operation, NSError *error) { }];}//tableView的相关代理//设置行高-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{ return 80;}//设置有多少条数据-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{ return _dataArray.count;}//有几个区-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{ return 1;}//给cell赋值-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ static NSString * string = @"cellID"; UITableViewCell * cell = [tableView dequeueReusableCellWithIdentifier:string]; if (!cell) { cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:string]; } cell.textLabel.text = [_dataArray objectAtIndex:indexPath.row]; return cell;}//检测tableView的滚动-(void)scrollViewDidScroll:(UIScrollView *)scrollView{ //这里有几个值要说明一下, //scrollView.contentOffset 这个时偏移量,下拉的时候这个时负数 //scrollView.contentSize 这个一般来说,会比当前的最大偏移量多出一个屏幕左右 //scrollView.frame tableView的frame NSLog(@"contentOffset : %@",NSStringFromCGPoint(scrollView.contentOffset)); NSLog(@"contentSize : %@",NSStringFromCGSize(scrollView.contentSize)); NSLog(@"frame : %@",NSStringFromCGRect(scrollView.frame)); //让上边的动画,跟着table的位置变化而变化,由于时先添加的,所以到带到前边 [UIView animateWithDuration:0.1 animations:^{ _refreshView.frame = CGRectMake(0, -100-scrollView.contentOffset.y, 375, 100); [self.view bringSubviewToFront:_refreshView]; }];}//tableView滚动结束后调用的方法-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{ //当检测到偏移量多余150点的时候,就让tableView上边空出100点来显示刷新view //然后显示正在刷新 //重载数据 if (scrollView.contentOffset.y < -150) { _tableView.contentInset = UIEdgeInsetsMake(100, 0, 0, 0); _refreshLabel.text = @"正在刷新"; [self createData]; }}- (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning];}@end
0 0
- iOS开发 ----- 下拉刷新
- iOS开发---MJRefresh下拉刷新/下拉加载
- 【iOS开发】---- 下拉刷新(附Demo)
- IOS开发——TabelView下拉刷新
- iOS 开发:上拉加载,下拉刷新
- iOS开发技巧 UIRefreshControl下拉刷新
- iOS开发笔记>> 下拉刷新,自定义UIControl
- iOS开发- MJRefresh第三方详解(下拉刷新,下拉加载)
- IOS UITableView下拉刷新
- ios 下拉刷新
- ios 下拉刷新
- ios下拉刷新
- IOS 下拉刷新--downPullRefreshView
- iOS 下拉刷新效果
- iOS 下拉刷新
- iOS 下拉刷新
- ios下拉刷新笔记
- IOS 6下拉刷新
- gauss 3种模板
- 杭电acm5480
- 行编译器-360笔试题
- select salary, job_id, hire_date into v_sal, v_job, v_date
- Codeforces Round #322 (Div. 2)
- iOS开发 ----- 下拉刷新
- Nosql数据库——redis(四)数据类型
- Please set ORACLE_UNQNAME to database unique name.的解决方案
- 超级流氓网站ddooo.com
- K皇后问题
- 流氓网站 星火软件veryhuo.com
- centos7.0 MYSQL rpm包的安装与其它的一些问题
- UVA 12086 Potentiometers(线段树裸题)
- 第一阶段考试