IOS下拉刷新 基于EGOTableViewPullRefresh实现

来源:互联网 发布:qq密码账号数据库泄露 编辑:程序博客网 时间:2024/06/05 10:25

EGOTableViewPullRefresh是在GitHub中的开源项目,针对ios的下拉刷新功能的一个框架,我们可以用来对其进行扩展或者实现ios的下拉刷新功能,EGOTableViewPullRefresh的下载地址:https://github.com/enormego/EGOTableViewPullRefresh,先下载源码,然后一步一步的来实现!



使用TableView配合EGOTableViewPullRefresh框架实现下拉刷新的效果:



1、创建项目将EGOTableViewPullRefresh框架放入项目中,并且再加入QuartzCore.framework因为EGOTableViewPullRefresh会用到这个框架。



2、在控制器中(ViewController)放入一个UITableView控件并且设置好关联跟代理,实现UITableView的代理函数,并且加入一些测试数据。

[java] view plaincopyprint?
  1. #import "PullViewController.h"  
  2.   
  3. @interface PullViewController (){  
  4.     //测试数据  
  5.     NSMutableArray *tableData;  
  6.  }  
  7.   
  8. @end  
  9.   
  10. @implementation PullViewController  
  11.   
  12. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil  
  13. {  
  14.     self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];  
  15.     if (self) {  
  16.      }  
  17.     return self;  
  18. }  
  19.   
  20. - (void)viewDidLoad  
  21. {  
  22.     //初始化一些数据用来填充tableView  
  23.     tableData = [[NSMutableArray alloc] initWithObjects:@"java",@"c/c++",@"python",@"objective-c",@"javascript", nil];  
  24.       
  25.     [super viewDidLoad];  
  26.  }  
  27.   
  28. - (void)didReceiveMemoryWarning  
  29. {  
  30.     [super didReceiveMemoryWarning];  
  31. }  
  32.   
  33. //返回tableView的分区个数  
  34. -(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{  
  35.     return 1;  
  36. }  
  37.   
  38. //返回tableView的行数  
  39. -(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{  
  40.     return [tableData count];  
  41. }  
  42.   
  43. //填充tableView的数据  
  44. -(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{  
  45.       
  46.     UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell"];  
  47.     if(cell==nil){  
  48.         cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Cell"];  
  49.     }  
  50.       
  51.     cell.textLabel.text = [tableData objectAtIndex:indexPath.row];  
  52.     return cell;  
  53. }  

运行效果:



4、在控制器头文件中导入EGOTableViewPullRefresh并且加入框架协议,定义两个刷新数据的函数:

[cpp] view plaincopyprint?
  1. #import <UIKit/UIKit.h>  
  2. #import "EGORefreshTableHeaderView.h"  
  3.   
  4. @interface PullViewController : UIViewController <UITableViewDataSource,UITableViewDelegate,EGORefreshTableHeaderDelegate>{  
  5.     BOOL reloading;  
  6.     EGORefreshTableHeaderView *refreshTableHeaderView;  
  7.   
  8. }  
  9. @property (retain, nonatomic) IBOutlet UITableView *tableView;  
  10.   
  11. - (IBAction)reloadButton:(id)sender;  
  12.   
  13. //function:  
  14.   
  15. - (void)reloadTableViewDataSource;//开始加载时调用此方法  
  16. - (void)doneLoadingTableViewData;//完成加载时调用此方法  
  17.   
  18.   
  19. @end  

5、在.m文件里的viewDidLoad函数中初始化EGOTableViewPullRefresh:

[cpp] view plaincopyprint?
  1. - (void)viewDidLoad  
  2. {  
  3.     //初始化一些数据用来填充tableView  
  4.     tableData = [[NSMutableArray alloc] initWithObjects:@"java",@"c/c++",@"python",@"objective-c",@"javascript", nil];  
  5.       
  6.     //初始化EGOTableViewPullRefresh  
  7.     if (refreshTableHeaderView ==nil) {  
  8.         EGORefreshTableHeaderView *view = [[EGORefreshTableHeaderView alloc] initWithFrame:CGRectMake(0.0f,0.0f - self.tableView.bounds.size.height,self.view.frame.size.width,self.tableView.bounds.size.height)];  
  9.         view.delegate = self;  
  10.         [self.tableView addSubview:view];  
  11.         refreshTableHeaderView = view;  
  12.         [view release];  
  13.     }  
  14.       
  15.     //更新刷新时间  
  16.     [refreshTableHeaderView refreshLastUpdatedDate];  
  17.       
  18.     [super viewDidLoad];  
  19.  }  

6、实现EGOTableViewPullRefresh的函数实现下拉刷新:reloadTableViewDataSource函数是刚刚在头文件中定义的函数,用来实现刷新数据在代码中让线程睡眠一段时间模仿数据调用的时间,并且给tableView增加一些新的数据最后刷新tableView。doneloadingTableViewData函数也是在头文件中定义的函数用来结束下拉刷新。

[cpp] view plaincopyprint?
  1. #pragma mark - 下拉操作:  
  2. - (void)reloadTableViewDataSource{  
  3.     reloading = YES;  
  4.     //线程睡眠一段时间,模仿数据调用  
  5.     [NSThread sleepForTimeInterval:3];  
  6.       
  7.     //给tableView添加一些数据  
  8.     [tableData addObjectsFromArray:[[NSArray alloc] initWithObjects:@"c#",@"php",@"t-sql", nil]];  
  9.     //刷新tableView  
  10.     [self.tableView reloadData];  
  11.     //后台操作线程执行完后,到主线程停止界面的刷新  
  12.     [self performSelectorOnMainThread:@selector(doneLoadingTableViewData) withObject:nil waitUntilDone:YES];  
  13. }  
  14.   
  15. - (void)doneLoadingTableViewData{  
  16.     reloading = NO;  
  17.     //结束下拉刷新  
  18.     [refreshTableHeaderView egoRefreshScrollViewDataSourceDidFinishedLoading:self.tableView];  
  19. }  
  20.   
  21.   
  22.   
  23. //当tableView滚动时就会调用这个函数  
  24. - (void)scrollViewDidScroll:(UIScrollView *)scrollView{  
  25.     NSLog(@"滚动时调用");  
  26.     [refreshTableHeaderView egoRefreshScrollViewDidScroll:scrollView];  
  27.       
  28. }  
  29. //当tableView滚动结束时就会调用这个函数  
  30. - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{  
  31.     NSLog(@"滚动结束时调用");  
  32.     [refreshTableHeaderView egoRefreshScrollViewDidEndDragging:scrollView];  
  33.       
  34. }  
  35.   
  36. #pragma mark EGORefreshTableHeaderDelegate function:  
  37. //当弹出下拉界面时调用此函数  
  38. - (void)egoRefreshTableHeaderDidTriggerRefresh:(EGORefreshTableHeaderView*)view{  
  39.     NSLog(@"下拉界面时");  
  40.     //调用reloadTableViewDataSource函数刷新tableView;  
  41.     [NSThread detachNewThreadSelector:@selector(reloadTableViewDataSource) toTarget:self withObject:nil];  
  42. }  
  43.   
  44. - (BOOL)egoRefreshTableHeaderDataSourceIsLoading:(EGORefreshTableHeaderView*)view{  
  45.     return reloading;    
  46.       
  47. }  
  48.   
  49. //最后一次改变的数据  
  50. - (NSDate*)egoRefreshTableHeaderDataSourceLastUpdated:(EGORefreshTableHeaderView*)view{  
  51.     return [NSDate date];   
  52. }  

实现效果:

 刷新后新增加的数据:


7、实现手动下拉刷新效果,为ViewController的界面中加入一个toolbar空间并且在toolbar上加入一个item button设置好关联:



8、编写手动下拉刷新代码:

[cpp] view plaincopyprint?
  1. #pragma mark 手动调用下拉刷新函数  
  2. -(void) ViewFrashData{  
  3.     //设置tableView的高度触发刷新事件  
  4.     [self.tableView setContentOffset:CGPointMake(0, -75) animated:YES];  
  5.       
  6.     [self performSelector:@selector(doneManualRefresh) withObject:nil afterDelay:0.4];  
  7. }  
  8.   
  9. //结束刷新  
  10. -(void)doneManualRefresh{  
  11.     [refreshTableHeaderView egoRefreshScrollViewDidScroll:self.tableView];  
  12.     [refreshTableHeaderView egoRefreshScrollViewDidEndDragging:self.tableView];  
  13. }  
  14.   
  15. //刷新按钮事件  
  16. - (void) reloadInfo{  
  17.     //手动下拉刷新相关  
  18.     [self ViewFrashData];  
  19. }  
  20.   
  21. //点击按钮刷新tableView  
  22. - (IBAction)reloadButton:(id)sender {  
  23.     [self reloadInfo];  
  24. }  

最终效果:点击刷新按钮实现刷新



0 0
原创粉丝点击