Skip to content

Instantly share code, notes, and snippets.

What would you like to do?
Animations with UIViewAnimationOptions
import UIKit
// MARK: RaceViewController
class RaceViewController: UIViewController {
// MARK: Outlets
@IBOutlet weak var raceButton: UIButton!
@IBOutlet weak var raceView: UIView!
@IBOutlet weak var purpleCar: UIImageView!
@IBOutlet weak var greyCar: UIImageView!
@IBOutlet weak var yellowCar: UIImageView!
@IBOutlet weak var purpleCarTopConstraint: NSLayoutConstraint!
@IBOutlet weak var greyCarTopConstraint: NSLayoutConstraint!
@IBOutlet weak var yellowCarTopConstraint: NSLayoutConstraint!
// MARK: Constants
let duration = 4.0 // Duration of the animation
let delay = 0.0 // Delay of the animation
let carHeight = 100 // Height of the race cars
// MARK: Action Methods
@IBAction func startRace(button: UIButton) {
let distance = raceView.frame.height - CGFloat(carHeight + 20)
// Purple car
UIView.animate(withDuration: duration, delay: delay, options: .curveEaseIn, animations: {
self.purpleCarTopConstraint.constant = distance
}, completion: nil)
// Grey car
UIView.animate(withDuration: duration, delay: delay, animations: {
self.greyCarTopConstraint.constant = distance
}, completion: nil)
// Yellow car
UIView.animate(withDuration: duration, delay: delay, options: .curveEaseOut, animations: {
self.yellowCarTopConstraint.constant = distance
}, completion: nil)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.