UIScrollView 的相关滑动代理回调方法及属性在滑动时的变化

如题, 虽然用了很多很多次 UIScrollView, 知道它有一些滑动代理回调方法, 知道它有一些滑动状态相关的属性, 但对这些方法在每一个时间点的具体状态总是不太确定, 看官方说明文档也是一头雾水. 索性这次将所有的代理方法及属性调用一遍, 然后记录下结果.

对于这种涉及到状态变化的描述, 文字似乎有些苍白无力, 于是我尝试用图表的方式来进行记录, 以期更加直观.

情景一: 拖拽加速然后松开自由滑动

himg
himg

如果滑动到底部, 且 ScrollViewbounces 回弹效果的话, 那么最后一次的 scrollViewDidScrollisDraging 属性为 false

情景二: 缓慢拖拽然后松开

himg
himg

总结

  • isDraging: 表示 scrollView 是否在自由滑动或者当前手指在接触屏幕

    A Boolean value that indicates whether the user has begun scrolling the content.
    

The value held by this property might require some time or distance of scrolling before it is set to true.

  • isTracking: 表示当前手指是否与屏幕接触

    Returns whether the user has touched the content to initiate scrolling.
    
  • The value of this property is true if the user has touched the content view but might not have yet have started dragging it.

  • isDecelerating: 这个简单的多, 就是表示是否正在减速, 也就是说只有当惯性滑动的时候才会为 true

    Returns whether the content is moving in the scroll view after the user lifted their finger.
    
  • The returned value is true if user isn’t dragging the content but scrolling is still occurring.

    Code

    为了便于读者独立测试验证, 这里附上完整代码

    //
    //  TableViewVC.swift
    //  HLTest
    //
    //  Created by Hanley Lee on 2021/5/19.
    //  Copyright © 2021 Hanley Lee. All rights reserved.
    //

    import UIKit

    class TableViewVCUITableViewController {

        var startTime: CFTimeInterval = .init()
        var des: String {
            return "isDragging: \(tableView.isDragging), isTracking: \(tableView.isTracking), isDecelerating: \(tableView.isDecelerating), interval: \(CACurrentMediaTime() - startTime)"
        }

        override func viewDidLoad() {
            super.viewDidLoad()
            tableView.rowHeight = 50
            tableView.register(TableViewCell.self, forCellReuseIdentifier: "TableViewCell")
            startTime = CACurrentMediaTime()
        }


        override func viewWillAppear(_ animated: Bool) {
            super.viewWillAppear(animated)
        }


        override func viewDidAppear(_ animated: Bool) {
            super.viewDidAppear(animated)
            let timer = Timer.scheduledTimer(withTimeInterval: 5, repeats: true) { _ in
                print(self.des)
            }

            RunLoop.current.add(timer, forMode: .common)
        }

    }

    // MARK: - Scroll Delegate

    extension TableViewVC {
        override func scrollViewDidScroll(_ scrollView: UIScrollView) {
            print("scrollViewDidScroll: \(des)")
        }

        override func scrollViewWillBeginDragging(_ scrollView: UIScrollView) {
            print("scrollViewWillBeginDragging: \(des)")
        }

        override func scrollViewWillEndDragging(_ scrollView: UIScrollView, withVelocity velocity: CGPoint, targetContentOffset: UnsafeMutablePointer<CGPoint>) {
            print("scrollViewWillEndDragging: \(des)")
        }

        override func scrollViewDidEndDragging(_ scrollView: UIScrollView, willDecelerate decelerate: Bool) {
            print("scrollViewDidEndDragging: \(des)")
        }

        override func scrollViewWillBeginDecelerating(_ scrollView: UIScrollView) {
            print("scrollViewWillBeginDecelerating: \(des)")
        }

        override func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {
            print("scrollViewDidEndDecelerating: \(des)")
        }
    }

    // MARK: - TableView Delegate & Data Source

    extension TableViewVC {

        override func numberOfSections(in tableView: UITableView) -> Int {
            return 1
        }

        override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return 100
        }

        override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            let cell = (tableView.dequeueReusableCell(withIdentifier: "TableViewCell"for: indexPath) asTableViewCell) ?? .init(frame: .zero)
            cell.setContent(with: indexPath.row.description)
            return cell
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值