Building Interruptible and Responsive Interactions
Show Apple's description.
Learn how to fluidly transition interactive UI elements from gesture-driven control to animated transitions. Take advantage of new iOS 8 behavior to smoothly transition between several animations on the same view. Discover architectural approaches to interfaces which remain interactive while they animate.
From Gesture to Animation
We have a few options here to implement this:
1. Using UIView animateWithDuration
This actually executes in another process out of context of your application. The render server(like back end) at a higher priority will make sure not dropping any frame on that animation, even the main thread is running a heavy work or blocked by some tasks. It would be easy to have a smooth animation if offload animation onto the render server by using animateWithDuration method.
Everything happening is in your process. Downside: it's easy to drop animate frame using this tech when thread is busy working on some task.
This is where UIDynamicAnimator built on. This calls you back once every frame.
Not recommended, highly possible to drop frames.
From Animation to Animation
|Absolute Animation||Absolute Animation and Begin from Current State|
- Smoother transitions on iOS 8 by default
- Still use BeginFromCurrentState if unsure
- Completion handlers may stack, since the change of animation would not stop or cancel the old animation, it actually create a new animation. Both of them would be finished.
|Additive Animation||Completion Handler|
|Absolute Animation||Additive Animation|
This note was originally published at