最近自己寫了一個(gè)下拉加載最新,上拉加載更多的刷新控件。借鑒了其他優(yōu)秀開源代碼的實(shí)現(xiàn)效果比如MJRefresh和DGElasticPullRefresh。主要是為了學(xué)習(xí)別人的優(yōu)秀思想。
如何使用:
Cocoapods 導(dǎo)入:pod 'ThPullRefresh',
在項(xiàng)目中 import 'ThPullRefresh'
手動導(dǎo)入:將'ThPullRefresh' 文件夾中的所有文件拽入項(xiàng)目中
head與foot基本效果的添加
具體代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
override func viewDidLoad() { super .viewDidLoad() self.tableView.registerClass(UITableViewCell.classForCoder(), forCellReuseIdentifier: "tableViewCell" ) self.tableView.rowHeight = UITableViewAutomaticDimension self.tableView.estimatedRowHeight = 44 self.tableView.tableFooterView = UIView() // self.tableView.addHeadRefresh(self) { () -> () in // self.loadNewData() // } self.tableView.addHeadRefresh(self, action: "loadNewData" ) self.tableView.head?.hideTimeLabel= true self.tableView.addFootRefresh(self, action: "loadMoreData" ) } func loadNewData(){ //延時(shí)模擬刷新 self.index = 0 DeLayTime( 2.0 , closure: { () -> () in self.dataArr.removeAllObjects() for (var i = 0 ;i< 5 ;i++){ let str = "最新5個(gè)cell,第\(self.index++)個(gè)" self.dataArr.addObject(str) } self.tableView.reloadData() self.tableView .tableHeadStopRefreshing() }) } |
DelayTime是一個(gè)方法的宏
1
2
3
|
func DeLayTime(x:Double,closure:()->()){ dispatch_after(dispatch_time(DISPATCH_TIME_NOW, Int64(x * Double(NSEC_PER_SEC))), dispatch_get_main_queue(), closure) } |
要實(shí)現(xiàn)果凍效果
代碼如下
幾個(gè)有顏色的點(diǎn)可以忽略,那是開發(fā)用于調(diào)貝塞爾曲線的。
1
2
3
4
5
6
7
8
|
/* *bgColor 背景顏色 *loadingColor 加載的顏色 */ public func addBounceHeadRefresh(target:AnyObject?,bgColor:UIColor,loadingColor:UIColor,action : Selector); //實(shí)現(xiàn)如下 self.tableView.addBounceHeadRefresh(self,bgColor:UIColor.orangeColor(),loadingColor:UIColor.blueColor(), action: "loadNewData" ) |
停止頭部刷新和底部刷新
1
2
|
self.tableView.tableHeadStopRefreshing() self.tableView.tableFootStopRefreshing |
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。