FanRefresh(Swift 刷新控件)

FanRefresh

现在swift上的库已经很多了,但是对比object-c还是很少,并且,swift版本变动太大,swift1.0-swift2.3经常变动,直到swift3.0出来,这个大版本变动后,才稳定,3.0-4.0变动不大,可以完美运行,现在已经支持最新swift4.0 ,并且对iOS 11适配希望你们喜欢,并且使用简单。

github项目主页:https://github.com/fanxiangyang/FanRefresh
Swift Refresh Lib (一个swift语言的上拉加载下拉刷新的库)
Introduce(介绍)
==============
FanRefresh ScrollView Refresh。
超级好用的上拉下拉,git图片定制,系统UIRefreshControl,其他用户可以自己定制DIY

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

Installation(安装)

CocoaPods

  1. Add pod 'FanRefresh','~> 0.1.0' 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
    • ImageIO

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()
})

4.下拉属性的修改

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-----------------------------------

5.系统自带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()
        }
    }
}

6.自定义Header GIF图片显示

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

//不转的话,没有属性可以掉用
let fanHeader=self.tableView.fan_header as! FanRefreshHeaderGIF
//隐藏时间
//        fanHeader.fan_lastUpdatedTimeLabel.isHidden=true
fanHeader.fan_height = 100
fanHeader.fan_setGifName(name: "loding1", gifState: .Default)
fanHeader.fan_setGifName(name: "loding", gifState: .Refreshing)
//        fanHeader.fan_setGifName(name: "loding1", gifState: .Pulling)
//上面可以这样替换,也可以放置png,jpg的image对象
fanHeader.fan_gifImages[.Pulling] = UIImage.fan_gif(name: "loding1")

//修改time与GIF间距默认5
//        fanHeader.fan_labelInsetTop=0
fanHeader.fan_gifImageView.fan_size=CGSize(width: 100, height: 60)

fanHeader.fan_lastUpdatedTimeLabel.textColor=UIColor.red
//fanHeader.fan_lastUpdatedTimeLabel.isHidden=true

7.自定义Footer GIF图片显示

weak var weakSelf=self
        //下拉
        self.tableView.fan_header = FanRefreshHeaderDefault.headerRefreshing(refreshingBlock: {
            weakSelf?.fan_loadData()
        })
        //上拉
        self.tableView.fan_footer=FanRefreshFooterGIF.footerRefreshing(refreshingBlock: {
            weakSelf?.fan_loadMoreData()
        })
        //不转的话,没有属性可以掉用
        let fanFooter=self.tableView.fan_footer as! FanRefreshFooterGIF
        
        //不建议在外部修改状态请使用方法
//        fanFooter.state = .NoMoreData//(不推荐写法)
//        fanFooter.fan_endRefreshingWithNoMoreData() //(推荐些法)
        
        //更新高度(不要直接self.fan_height = 120)
        fanFooter.fan_UpdateHeight(height: 120)
        fanFooter.fan_setGifName(name: "loding1", gifState: .Default)
        fanFooter.fan_setGifName(name: "loding", gifState: .Refreshing)
        //        fanFooter.fan_setGifName(name: "loding1", gifState: .NoMoreData)
        //上面可以这样替换,也可以放置png,jpg的image对象
        fanFooter.fan_gifImages[.NoMoreData] = UIImage.fan_gif(name: "loding1")
        
        //修改time与GIF间距默认5
        fanFooter.fan_labelInsetLeft=0
        fanFooter.fan_gifImageView.fan_size=CGSize(width: 100, height: 60)
        
        fanFooter.fan_stateLabel.textColor=UIColor.red
        fanFooter.backgroundColor=UIColor.yellow
//        fanFooter.fan_isRefreshTitleHidden = true

更新历史(Version Update)

Release 0.0.3

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

Release 0.0.4

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

Release 0.0.5

  • 修复中文字符串长度越界问题
  • 修复调用时间记录初次为空时崩溃的处理
  • 添加Header和Footer的自定义GIF展示

Release 0.1.0

  • swift4编译,iOS 11适配
  • iOS 11,tableview高度变化,不用添加任何代码,完全搞定

Like(喜欢)

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

Email:[email protected]

github主页:https://github.com/fanxiangyang

后续会持续更新,希望喜欢的可以关注我

你可能感兴趣的:(FanRefresh(Swift 刷新控件))