introduce

Animation can often play a role in enhancing user experience. In iOS development, we can use the animation provided by UIKit, or UIView animation for short. UIView Animation is essentially an encapsulation of Core Animation, providing a concise Animation API.

Common animation

  • API
/ / the most complete
open class func animate(withDuration duration: TimeInterval.delay: TimeInterval.options: UIView.AnimationOptions= [].animations: @escaping() - >Void.completion: ((Bool) - >Void)? = nil)

open class func animate(withDuration duration: TimeInterval.animations: @escaping() - >Void.completion: ((Bool) - >Void)? = nil) // The simplestopen class func animate(withDuration duration: TimeInterval.animations: @escaping() - >Void)
Copy the code
  • Parameter meaning
    • Duration: Duration of the animation.
    • Delay: The time the animation is delayed to execute.
    • Uiview. AnimationOptions: Animation transition effects that can be used in combination.
    • Animations: Animations that are performed.
    • Completion: Indicates the operation after the animation is completed.

case

// Two parameters
// Put the statement that you want to animate into the closure
UIView.animate(withDuration: 0.5) {
    view.backgroundColor = UIColor.red
}

// You can animate multiple properties simultaneously in a closure
UIView.animate(withDuration: 0.5) {
    view.backgroundColor = UIColor.red
    view.center.y + = 100
    view.alpha = 0
}

// Three parameters
UIView.animate(withDuration: 0.5) {
    view.backgroundColor = UIColor.red
} completion: { _ in
    print("Animation completed.")}// Five parameters
UIView.animate(withDuration: 0.5, delay: 0.5, options: .curveLinear) {
    view.backgroundColor = UIColor.red
} completion: { _ in
    print("Animation completed.")}// If placed in the performWithoutAnimation closure, the animation will not be executed
UIView.animate(withDuration: 0.5) {
    view.backgroundColor = UIColor.red
    
    UIView.performWithoutAnimation {
        view.alpha = 0.2}}Copy the code

UIView.AnimationOptions

Common AnimationOptions are:

  • CurveEaseInOut: time curve that starts slow, accelerates, and decelerates (default).
  • CurveEaseIn: A time curve that starts slow and gets faster and faster.
  • CurveEaseOut: A time curve that starts fast and gets slower and slower.
  • CurveLinear: Time curve, constant speed.
  • Repeat: When this option is specified, the animation repeats indefinitely.
  • Autoreverse: round-trip animation that runs from the start to the end and then back to the start again.
  • Animated preferredFramesPerSecond30: specify the refresh rate for 30 FPS.
  • Refresh rate is 60 FPS preferredFramesPerSecond60: specify the animation.

To stop the animation

view.layer.removeAllAnimations()
Copy the code

Spring animation

  • Also known as Spring Animation.
  • API
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)
Copy the code
  • Parameter meaning
    • Duration: Duration of the animation.
    • Delay: The time the animation is delayed to execute.
    • DampingRatio: shock effect. The range is 0 to 1. The smaller the value, the more obvious the shock effect.
    • Velocity: Initial velocity. The greater the value, the faster the initial velocity.
    • Uiview. AnimationOptions: Animation transition effects that can be used in combination. (Similar to normal animation).
    • Animations: Animations that are performed.
    • Completion: Indicates the operation after the animation is completed.

case

// Compare the three animations
UIView.animate(withDuration: 3.0, delay: 0, usingSpringWithDamping: 0.1, initialSpringVelocity: 0, options: .curveEaseIn, animations: {
    blueView.center.y + = 300
}, completion: nil)

UIView.animate(withDuration: 3.0, delay: 0, usingSpringWithDamping: 0.5, initialSpringVelocity: 10, options: .curveEaseIn, animations: {
    greenView.center.y + = 300
}, completion: nil)

UIView.animate(withDuration: 3.0, delay: 0, usingSpringWithDamping: 0.9, initialSpringVelocity: 20, options: .curveEaseIn, animations: {
    redView.center.y + = 300
}, completion: nil)
Copy the code

Animated transitions

  • API
// The transition effect for a single view
open class func transition(with view: UIView.duration: TimeInterval.options: UIView.AnimationOptions= [].animations: (() - >Void)? .completion: ((Bool) - >Void)? = nil) // Animation from old view to new viewopen class func transition(from fromView: UIView.to toView: UIView.duration: TimeInterval.options: UIView.AnimationOptions= [].completion: ((Bool) - >Void)? = nil)
Copy the code
  • Parameter meaning
    • View: The view that generates the animation.
    • FromView: During the animation, the fromView is removed from the superview.
    • ToView: When fromView disappears, toView is added to the superview.
    • Duration: Duration of the animation.
    • Uiview. AnimationOptions: Animation transition effects that can be used in combination. (Transition starts with transition).
    • Animations: Animations that are performed.
    • Completion: Indicates the operation after the animation is completed.

case

  • Methods a
UIView.transition(with: self.redView, duration: 2.0, options: .transitionCurlUp, animations: { 
    let orangeView = UIView(frame: CGRect(x: 0, y: 0, width: 100, height: 100))    
    orangeView.center = self.redView.center
    orangeView.backgroundColor = UIColor.orange  
    self.redView.addSubview(orangeView)    
}, completion: nil)
Copy the code
  • Way 2
let orangeView = UIView(frame: CGRect(x: 0, y: 0, width: 100, height: 100))
orangeView.backgroundColor = UIColor.orange
UIView.transition(from: self.redView, to: orangeView, duration: 2.0, options: .transitionFlipFromRight, completion: nil)
Copy the code

Coordinate transformation

Thinking: The orangeview.center = self.redview.center set in method 1 does not achieve the desired effect, why?

Because redView and orangeView do not refer to the same coordinate system, a coordinate transformation is required.

There are two kinds of coordinate transformation, one is CGPoint transformation, the other is CGRect transformation.

CGPoint conversion
// Convert the self.redview.center (point argument) of self.view (from argument) to self.redview (caller)
orangeView.center = self.redView.convert(self.redView.center, from: self.view)
// self.view (caller) converts self.redview.center (point argument) to self.redview (to argument)
orangeView.center = self.view.convert(self.redView.center, to: self.redView)
Copy the code
CGRect conversion
// The orangeview. frame (rect argument) of self.redview (from argument) is converted to self.view (caller)
orangeView.frame = self.view.convert(orangeView.frame, from: self.redView)
// self.view (caller) converts self.redview.frame (rect argument) to self.redview (to argument)
self.redView.frame = self.view.convert(self.redView.frame, to: self.redView)
Copy the code

Keyframe animation

  • API
open class func animateKeyframes(withDuration duration: TimeInterval.delay: TimeInterval.options: UIView.KeyframeAnimationOptions= [].animations: @escaping() - >Void.completion: ((Bool) - >Void)? = nil)

open class func addKeyframe(withRelativeStartTime frameStartTime: Double.relativeDuration frameDuration: Double.animations: @escaping() - >Void)
Copy the code
  • Parameter meaning
    • Duration: The total duration of the animation.
    • Delay: The time the animation is delayed to execute.
    • UIView. KeyframeAnimationOptions: the transition of animation effect, can be combined.
    • Animations: Keyframe animations performed.
    • Completion: Indicates the operation after the animation is completed.
    • FrameStartTime: The time when the animation started (as a percentage of the total time).
    • RelativeDuration: Duration of the animation as a percentage of the total time.
    • Animations: Animated frames performed.

case

class ViewController: UIViewController {
    @IBOutlet var leaf: UIImageView!

    override func viewDidLoad(a) {
        super.viewDidLoad()
    }

    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?). {
        UIView.animateKeyframes(withDuration: 6.0, delay: 0, options: .calculationModeCubic, animations: {
            UIView.addKeyframe(withRelativeStartTime: 0, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 108, y: 260)})UIView.addKeyframe(withRelativeStartTime: 0.1, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 138, y: 340)})UIView.addKeyframe(withRelativeStartTime: 0.2, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 168, y: 420)})UIView.addKeyframe(withRelativeStartTime: 0.3, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 200, y: 490)})UIView.addKeyframe(withRelativeStartTime: 0.4, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 248, y: 570)})UIView.addKeyframe(withRelativeStartTime: 0.5, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 278, y: 630)})UIView.addKeyframe(withRelativeStartTime: 0.6, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 308, y: 690)})UIView.addKeyframe(withRelativeStartTime: 0.7, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 318, y: 770)})UIView.addKeyframe(withRelativeStartTime: 0.8, relativeDuration: 0.1, animations: {
                self.leaf.center = CGPoint(x: 328, y: 860)})UIView.addKeyframe(withRelativeStartTime: 0.9, relativeDuration: 0.1, animations: {
                self.leaf.transform = CGAffineTransform(rotationAngle: CGFloat(Float.pi * 0.25))
            })
        }, completion: nil)}}Copy the code

UIView.KeyframeAnimationOptions

Common KeyframeAnimationOptions include:

  • CalculationModeLinear: Operation mode, continuous.
  • CalculationModeDiscrete: Operation mode, discrete.
  • CalculationModePaced: Operation pattern, even execution.
  • CalculationModeCubic: Operation mode, smooth.
  • CalculationModeCubicPaced: operation mode, smoothly.
  • Repeat: When this option is specified, the animation repeats indefinitely.
  • Autoreverse: round-trip animation that runs from the start to the end and then back to the start again.