高度自定义的线性下拉刷新控件 SJLineRefresh
完全自定义路径
多种内置动画
swift 3.0+
使用
1.基础用法
let aPath = Bundle.main.path(forResource: 'HHMedic', ofType: 'plist')! let aConfig = SJRefreshConfig(plist: aPath) tableView.sj_header = SJRefreshView(config: aConfig) { [weak self] in // do your refresh }2.全局设置
let aPath = getCurrentBundle().path(forResource: 'HHMedic', ofType: 'plist') ?? '' SJRefreshManager.default.defaultConfig = SJRefreshConfig(plist: aPath) // 设置全局config tableView.sj_header = SJRefreshView.default { [weak self] in // 刷新回调 // 结束刷新 self?.tableView.endRefresh() } // plist只加载一次3.手动刷新/结束
tableView.beginRefresh() // 手动开始刷新 tableView.endRefresh() // 结束刷新4.动画参数
startRatio // 开始动画的起始点与整个高度的比例 endRatio // 结束动画的起始点与整个高度的比例 stepLength // 每个line'闪烁'所用时间 stepDuration // '闪烁'的动画时长 style // 动画类型 normal // 默认 stay // '闪烁'完成后保持闪烁状态 step // 下拉时,一个line绘制完成后才继续下一个绘制 reverse //从最后一个line往前'闪烁创建形状
- 使用PaintCode画线, 在plist中写入对应的所有线条的起始点和终点(数量要保持一致) - 下拉刷新视图的宽高等于起点和终点的最大距离, 居中对齐安装
CocoaPods
pod 'SJLineRefresh', '~> 1.1.1'Carthage
github '515783034/SJLIineRefresh' ~> 1.1.1,开题报告,开题报告