Skip to content

wangjianan186/FanRefresh

 
 

Repository files navigation

FanRefresh

Swift Refresh Lib (一个swift语言的上拉加载下拉刷新的库)

Introduce(介绍)

FanRefresh ScrollView Refresh。

超级好用的上拉下拉,git图片定制,系统UIRefreshControl,其他用户可以自己定制DIY

  • Refresh — 基本类扩展和常量定义。
  • Header — 下拉刷新控件。
  • Footer — 上拉加载控件。

Installation(安装)

CocoaPods

  1. Add pod 'FanRefresh','~> 0.0.3' to your Podfile.
  2. Run pod install or pod update.
如果 pod search FanRefresh 查找不到,更新本地spec仓库 pod setup 或者 pod repo update 结果还是查不到:清空搜索缓存再查询 rm ~/Library/Caches/CocoaPods/search_index.json 

手动安装

  1. 下载 FanRefresh项目
  2. 将 FanRefresh项目里面Classes文件夹及内的源文件添加(拖放)到你的工程。
  3. 链接以下 frameworks:
    • UIKit
    • Foundation

Requirements(系统要求)

FanRefresh该项目最低支持 iOS 8.0。

注意:应该能够支持到iOS7的,没有设备尝试,如果不能可以告诉我

Function Example(功能事例)

1.Example List(功能列表)

动画

2.下拉刷新

weak var weakSelf=self //下拉 self.tableView.fan_header = FanRefreshHeaderDefault.headerRefreshing(refreshingBlock: { weakSelf?.fan_loadData() }) 

3.上拉加载

weak var weakSelf=self //上拉 self.tableView.fan_footer=FanRefreshFooterDefault.footerRefreshing(refreshingBlock: { weakSelf?.fan_loadMoreData() }) 

3.下拉属性的修改

weak var weakSelf=self //下拉 self.tableView.fan_header = FanRefreshHeaderDefault.headerRefreshing(refreshingBlock: { weakSelf?.fan_loadData() }) //不转的话,没有属性可以掉用 let fanHeader=self.tableView.fan_header as! FanRefreshHeaderDefault //修改背景颜色(默认透明) fanHeader.backgroundColor=UIColor.yellow //文字与菊花之间的间距(默认20) fanHeader.fan_labelInsetLeft=40.0 //修改状态字体内容(默认支持 中文,繁体中文,和英文) fanHeader.fan_setTitle(title: "下拉可以刷新", state: .Default) fanHeader.fan_setTitle(title: "松开立即刷新", state: .Pulling) fanHeader.fan_setTitle(title: "正在刷新数据中...", state: .Refreshing) //修改状态和时间显示的字体颜色和大小样式 fanHeader.fan_stateLabel.textColor=FanRefreshColor(r: 250, g: 34, b: 43, a: 1) fanHeader.fan_stateLabel.font=UIFont.boldSystemFont(ofSize: 14) // MARK: HeaderRefresh特有的 //--------------------------------特有begain----------------------------------- //下拉时透明度自动增强(默认true) fanHeader.fan_automaticallyChangeAlpha=false //修改时间显示的字体颜色和大小样式 fanHeader.fan_lastUpdatedTimeLabel.textColor=FanRefreshColor(r: 250, g: 34, b: 43, a: 1) //外部修改时间控件的显示内容(默认正确的时间,可以+,可以-) fanHeader.fan_lasUpdateTimeText = { ( lastUpdatTime ) in return "2017-04-01 12:00:00" } //添加5秒种后再次进入界面,自动下拉刷新 //如果启用这个方式,最好启动时,直接调用 fanHeader.fan_beginRefreshing() fanHeader.fan_autoRefresh(thanIntervalTime: 5.0) //--------------------------------特有end----------------------------------- 

4.系统自带UIRefreshControl刷新

//系统自带简洁下拉 override func viewDidLoad() { super.viewDidLoad() self.dataArray=Array() let refreshControl = FanRefreshControl.fan_addRefresh(target: self, action: #selector(fan_loadDataControl))	//这样也是可以的	if #available(iOS 10.0, *) { self.tableView?.refreshControl = refreshControl	}else{ self.tableView?.fan_refreshControl = refreshControl } } //加载数据,模拟2秒后刷新 func fan_loadDataControl() { if #available(iOS 10.0, *) { (self.tableView?.refreshControl as! FanRefreshControl).fan_beginRefreshing() }else{ self.tableView?.fan_refreshControl?.fan_beginRefreshing() } weak var weakTableView=self.tableView DispatchQueue.main.asyncAfter(deadline: DispatchTime.now()+2.0) { //这里修改数据,能防止cell复用时调用cell代理数组越界问题 self.dataArray = ["6","7","8","9","10"] weakTableView?.reloadData() if #available(iOS 10.0, *) { weakTableView?.refreshControl?.endRefreshing() }else{ weakTableView?.fan_refreshControl?.endRefreshing() } } } 

更新历史(Version Update)

Release 0.0.3

  • 支持简单的上拉和下拉刷新,没有GIF图片

Release 0.0.4

  • 简化枚举属性
  • 添加系统控件UIRefreshControl实现下拉刷新(可兼容iOS10)

Like(喜欢)

有问题请直接在文章下面留言,喜欢就给个Star(小星星)吧!

About

a swift Refresh control (pod FanRefresh -> 0.0.3)

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages

  • Swift 97.7%
  • Ruby 2.3%