最近自己寫了一個下拉加載最新,上拉加載更多的刷新控件。借鑒了其他優秀開源代碼的實現效果比如MJRefresh和DGElasticPullRefresh。主要是為了學習別人的優秀思想。
如何使用:
Cocoapods 導入:pod 'ThPullRefresh',
在項目中 import 'ThPullRefresh'
手動導入:將'ThPullRefresh' 文件夾中的所有文件拽入項目中
head與foot基本效果的添加
具體代碼如下:
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(){ //延時模擬刷新 self.index = 0 DeLayTime(2.0, closure: { () -> () in self.dataArr.removeAllObjects() for (var i = 0 ;i<5;i++){ let str = "最新5個cell,第/(self.index++)個" self.dataArr.addObject(str) } self.tableView.reloadData() self.tableView .tableHeadStopRefreshing() }) }
DelayTime是一個方法的宏
func DeLayTime(x:Double,closure:()->()){dispatch_after(dispatch_time(DISPATCH_TIME_NOW, Int64(x * Double(NSEC_PER_SEC))), dispatch_get_main_queue(), closure)}
要實現果凍效果
代碼如下
幾個有顏色的點可以忽略,那是開發用于調貝塞爾曲線的。
/* *bgColor 背景顏色 *loadingColor 加載的顏色 */ public func addBounceHeadRefresh(target:AnyObject?,bgColor:UIColor,loadingColor:UIColor,action : Selector); //實現如下self.tableView.addBounceHeadRefresh(self,bgColor:UIColor.orangeColor(),loadingColor:UIColor.blueColor(), action: "loadNewData")
停止頭部刷新和底部刷新
self.tableView.tableHeadStopRefreshing()self.tableView.tableFootStopRefreshing
以上就是本文的全部內容,希望對大家的學習有所幫助。