iOS17适配指南之弹簧动画

2023-06-28  本文已影响0人  YungFan

介绍

open class func animate(withDuration duration: TimeInterval,
                        delay: TimeInterval,
                        usingSpringWithDamping dampingRatio: CGFloat,
                        initialSpringVelocity velocity: CGFloat,
                        options: UIView.AnimationOptions = [],
                        animations: @escaping () -> Void,
                        completion: ((Bool) -> Void)? = nil)
@available(iOS 17.0, macOS 14.0, tvOS 17.0, watchOS 10.0, *)
@MainActor public class func animate(springDuration duration: TimeInterval = 0.5,
                                     bounce: CGFloat = 0.0,
                                     initialSpringVelocity: CGFloat = 0.0,
                                     delay: TimeInterval = 0.0,
                                     options: UIView.AnimationOptions = [],
                                     animations: () -> Void,
                                     completion: ((Bool) -> Void)? = nil)

参数含义

案例

import UIKit

class ViewController: UIViewController {
    lazy var redView: UIView = {
        let view = UIView(frame: CGRect(x: 0, y: 50, width: 100, height: 100))
        view.backgroundColor = .red
        return view
    }()
    lazy var greenView: UIView = {
        let view = UIView(frame: CGRect(x: 120, y: 50, width: 100, height: 100))
        view.backgroundColor = .green
        return view
    }()
    lazy var blueView: UIView = {
        let view = UIView(frame: CGRect(x: 240, y: 50, width: 100, height: 100))
        view.backgroundColor = .blue
        return view
    }()

    override func viewDidLoad() {
        super.viewDidLoad()

        view.addSubview(blueView)
        view.addSubview(greenView)
        view.addSubview(redView)
    }

    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        animate()
    }
}

extension ViewController {
    // MARK: UIView动画
    func animate() {
        // 3个不同参数的弹簧动画对比
        UIView.animate(springDuration: 1.5, bounce: 0) {
            self.redView.center.y = 300
        }
        UIView.animate(springDuration: 1.5, bounce: 0.5, initialSpringVelocity: 5) {
            self.greenView.center.y = 300
        }
        UIView.animate(springDuration: 1.5,
                       bounce: 0.9,
                       initialSpringVelocity: 10,
                       delay: 0,
                       options: .curveLinear,
                       animations: {
                           self.blueView.center.y = 300
                       }, completion: nil)
    }
}

效果

弹簧动画.gif
上一篇 下一篇

猜你喜欢

热点阅读