animateWithDuration(_:animations:completion:)
, which is a method on UIView
, is great for simple animations. But when we need to build a sequence of animations, chaining together completion is verbose and difficult to adjust.
The keyframe animation methods provide a better alternative when building multi-part animations. Let's use them to make a "bounce" effect.
This is your goal:
You'll need UIKeyFrameAnimations
Note how Bon Jovi "bounces" when the button is tapped -- the image first shrinks, then expands outward (slightly past its final size), then comes to a rest at a height that fills the screen. When the image shrinks, it goes through the same process in reverse. This sort of multi-step animation is perfect for the keyframe animation methods in UIKit.
Implement this animation by adjusting constraints on the image view. Check out the storyboard -- there are currently no constraints controlling the height and y-position of the image view.
So, your process should be something like this:
-
Add constraints that will let you easily animate the image as desired. Think about your options -- you could pin down the image view's height and top, but would that be easy to animate in the desired way?
Hint: does the center-y of the image view change across animations? Maybe you could pin it down, and just animate between two height constraints.
-
Make Bon Jovi grow in the
expandButtonTapped(_:)
method (we'll handle the toggling later). You'll need to build a keyframe animation that implements the "bounce" effect. It will have steps close to this:- Shrink slightly below the starting height
- Grow slightly beyond the height of the screen
- Shrink back down to the exact height of the screen.
The animation should work on phones of all sizes and orientations. Don't hard-code the screen's height!
-
Make the
expandButtonTapped(_:)
method toggle between the full-height and normal sizes of the image view. You'll probably have to add a flag property so you know whether to expand or shrink. The shrink animation should be the exact opposite of the expansion one:- Grow slightly beyond the height of the screen
- Shrink down to slightly below the final height of the image
- Return to the exact starting height
View You Give Love A Bad Name on Learn.co and start learning to code for free.