LTInfiniteScrollViewSwift 0.5.0

LTInfiniteScrollViewSwift 0.5.0

测试已测试
语言语言 SwiftSwift
许可证 MIT
发布上次发布2017年1月
SPM支持 SPM

ltebean 维护。



  • 作者:
  • ltebean

演示

1. 您可以在滚动时为每个视图应用动画

LTInfiniteScrollView

2. 在本库的支持下,可以在十分钟内实现 iOS 9 任务切换器的动画

LTInfiniteScrollView

3. 好看的菜单也可以轻松实现

LTInfiniteScrollView

您可以在 Objective-C 版本的完整演示中找到:https://github.com/ltebean/LTInfiniteScrollView

安装

pod 'LTInfiniteScrollViewSwift'

或者直接将 LTInfiniteScrollView.swift 拷贝到您的项目中。

使用

您可以通过以下方式创建滚动视图:

scrollView = LTInfiniteScrollView(frame: CGRect(x: 0, y: 200, width: screenWidth, height: 300))
scrollView.dataSource = self
scrollView.delegate = self
scrollView.maxScrollDistance = 5
scrollView.reloadData(initialIndex: 0)

然后实现 LTInfiniteScrollViewDataSource 协议

public protocol LTInfiniteScrollViewDataSource: class {
    func viewAtIndex(index: Int, reusingView view: UIView?) -> UIView
    func numberOfViews() -> Int
    func numberOfVisibleViews() -> Int
}

示例代码

func numberOfViews() -> Int {
    return 100
}

func numberOfVisibleViews() -> Int {
    return 5
}

func viewAtIndex(index: Int, reusingView view: UIView?) -> UIView {
    if let label = view as? UILabel {
        label.text = "\(index)"
        return label
    }
    else {
        let size = screenWidth / CGFloat(numberOfVisibleViews())
        let label = UILabel(frame: CGRect(x: 0, y: 0, width: size, height: size))
        label.textAlignment = .Center
        label.backgroundColor = UIColor.darkGrayColor()
        label.textColor = UIColor.whiteColor()
        label.layer.cornerRadius = size / 2
        label.layer.masksToBounds = true
        label.text = "\(index)"
        return label
    }
}

如果您希望在滚动过程中应用任何动画,实现 LTInfiniteScrollViewDelegate 协议

public protocol LTInfiniteScrollViewDelegate: class {
    func updateView(view: UIView, withProgress progress: CGFloat, scrollDirection direction: ScrollDirection)
}

进度值的范围取决于该视图的位置;如果有 5 个可见视图,则值的范围在 -2 到 2 之间

|                  |
|-2  -1   0   1   2|
|                  |

您可以克隆项目并查看示例以获取详细信息。