iOS 动画十九:Intermediate Animations with UIViewPropertyAnimator

1. Built-in timing curves

现在看一个例子,模拟器上面效果不好,最好真机上面看。

 func toggleBlur(_ blurred: Bool) {
    
    // 1. 测试1
//    UIViewPropertyAnimator.runningPropertyAnimator(
//      withDuration: 0.5, delay: 0.1, options: .curveEaseOut,
//      animations: {
//        self.blurView.alpha = blurred ? 1 : 0
//      },
//      completion: nil
//    )
    
    // 2. 测试2
    // AnimatorFactory.fade(view: blurView, visible: blurred)
    
    // 3. 测试3
    UIViewPropertyAnimator(duration: 0.55, curve: .easeOut,
                        animations:blurAnimations(blurred)).startAnimation()
    
    // 4. 测试4
    // UIViewPropertyAnimator(duration: 0.55,
    //      controlPoint1: CGPoint(x: 0.57, y: -0.4),
    //      controlPoint2: CGPoint(x: 0.96, y: 0.87),
    //      animations: blurAnimations(blurred)).startAnimation()
  }
复制代码
func blurAnimations(_ blurred: Bool) -> () -> Void {
    return {
      self.blurView.effect = blurred ? UIBlurEffect(style: .dark) : nil
      self.tableView.transform = blurred ? CGAffineTransform(scaleX: 0.75, y: 0.75) : .identity
      self.tableView.alpha = blurred ? 0.33 : 1.0
    }
  }
复制代码

curve 参数类型为 UIViewAnimationCurve。 该枚举包括四种类型: .linear, .easeIn, .easeOut, and easeInOut。你可以依次看看它们有何不同。

2. Custom Bézier curves

什么是 Bézier 曲线呢?

让我们看看一条从点 A 开始到点 B 结束的直线。

能够如此精确地在屏幕上描述形状的便利方法使我们还可以对其应用变换:我们可以缩放、移动或者旋转它。一切都归功于坐标系中的这两点。 此外,我们还可以将 lines 保留到磁盘并将其加载回来,因为我们可以使用数字来描述它们,并且知道如何保留它。

而曲线比直线有趣多了,它可以绘制更多图样。

eg.

曲线不是随机的,它们也有一些像直线一样的特殊点,可以通过坐标来定义它们。

可以通过向线条添加控制点(control points)来定义曲线 :

我们可以想象它是由铅笔绘制的连接到线的曲线(曲线始终与由 AC 上的点连接到 BC 线上的点的那条直线相切),其起点沿着线 AC 移动,其终点沿着线 CB 移动:

具有一个控制点的 Bézier 曲线称为二次曲线。 但是,我们对立方 Bézier 曲线会更感兴趣 - 那些曲线有两个控制点。

我们可以使用三次曲线来描述动画计时。 实际上,我们使用的内置曲线也是预先定义的三次曲线。

Core Animation 使用始终以坐标(0,0)开始的三次曲线,它代表动画持续时间的开始。 这些时序曲线的终点始终是(1,1) -- 动画的持续时间和进度的结束。

让我们来看看 ease-in curve :

随着时间的推移(在坐标空间中从左向右水平移动),开始曲线在垂直轴上的进展非常小,然后大约在动画持续时间的一半时间后,进度加快并随着时间的推移而赶上,因此它们在动画结束时都达到了点(1,1)。

想更形象了解贝塞尔曲线,可以看看这个,贝塞尔动画

想更多了解,请访问官网: http://cubic-bezier.com

弄清楚了贝塞尔曲线,我们对 PS 中钢笔工具的使用会更得心应手。

3. Spring Animations

方法 —UIViewPropertyAnimator(duration:dampingRatio:animations:) 可以定义 spring driven animations。

这将产生与调用 UIView 的(withDuration:delay:usingSpringWithDamping:initialSpringVelocity:options:animations:completion:) 方法相同的动画,动画初始速度为 0。

通过 UIViewPropertyAnimator(duration:timingParameters:) ,我们可以创建一个全新的对象,可以为动画提供计时数据,可以使用其中一个 UIKit 对象来定义自定义立方体或基于弹簧的时序(custom cubic or spring based timings)。

参数 timingParameters 是由 UIKit 定义的 UITimingCurveProvider 类型协议。 UIKit 中有两个符合该协议的类:UICubicTimingParameters 和 UISpringTimingParameters。

让我们来看看 UISpringTimingParameters :

Providing damping and velocity

使用 custom timing provider ,就像使用 convenience initializer 时一样,我们仍然可以选择简单的方法,并提供阻尼比和初始速度(damping ratio and initial velocity)。

let spring = UISpringTimingParameters(dampingRatio:0.5, initialVelocity: CGVector(dx: 1.0, dy: 0.2))
let animator = UIViewPropertyAnimator(duration: 1.0, timingParameters: spring)
复制代码

初始速度是矢量类型。 如果要为视图的位置或大小设置动画,UIKit 将在开始时应用二维初始速度。 如果要为视图的位置设置 alpha 或单个轴(single axis)的动画,UIKit 将仅考虑初始速度矢量的 dx 属性。

initialVelocity 是一个可选参数,如果我们根本不需要设置速度,只需提供阻尼比(damping ratio)即可。

Custom springs

如果想更多的自定义弹簧的特性,可以在 UISpringTimingParameters 上使用不同的初始化器,指定弹簧的质量,刚度和阻尼等。

eg.

let spring = UISpringTimingParameters(mass: 10.0, stiffness: 5.0, damping: 30, initialVelocity: CGVector(dx: 1.0, dy: 0.2))
let animator = UIViewPropertyAnimator(duration: 1.0, t imingParameters: spring)
复制代码
4. Auto Layout animations

Auto Layout animations 工厂方法

@discardableResult
  static func animateConstraint(view: UIView, constraint:
    NSLayoutConstraint, by: CGFloat) -> UIViewPropertyAnimator {
    let spring = UISpringTimingParameters(dampingRatio: 0.55)
    let animator = UIViewPropertyAnimator(duration: 1.0, timingParameters: spring)// 1.0
    animator.addAnimations {
      constraint.constant += by // 这里是 Auto Layout animations
      view.layoutIfNeeded()
    }
    return animator
  }
复制代码

需要调用的地方直接调用方法调用即可。

AnimatorFactory.animateConstraint(view: view, constraint: dateTopConstraint, by: 100).startAnimation()
复制代码

demo 下载

转载于:https://juejin.im/post/5c452c4ce51d451d200e3a00

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值