RBBAnimation is a subclass of
CAKeyframeAnimation that allows you to use
blocks to describe your animation instead of having to write out every frame by
It comes out of the box with a replacement for CASpringAnimation, support for custom easing functions such as bouncing as well as hooks to allow you to write your own animations fully from scratch.
RBBCustomAnimation is the most flexible of the
To use it, simply create a new animation as you normally would
an pass in an
RBBAnimationBlock from which you return the desired value for a
given point in time.
That being said, you'll probably want to use the higher-level
RBBTweenAnimation is similar to
CABasicAnimation in that it smoothly
interpolates between two values. Unlike CABasicAnimation however, it supports a
wider variety of easing functions.
Easing functions (or timing functions) are used to describe how fast values
change during an animation. Core Animation comes with the
CAMediaTimingFunction class, but it's limited to cubic Bézier curves.
They are also available for
RBBTweenAnimation through the RBBCubicBezier
RBBTweenAnimation also supports more complex easing functions such as
If you fancy, you can also specify your own easing functions, like this sine wave here, from scratch:
While Core Animation comes with a
CASpringAnimation class to model damped
springs, it's private API and thus (more or less) off-limits, quite a shame
since it's a really gorgeous effect.
RBBSpringAnimation as a replacement, simply specify the
stiffness as well as its initial velocity and watch
You can find the code on GitHub, it's MIT licensed and also available through CocoaPods.
I hope RBBAnimation will be useful to you. If you end up using it in one of your apps, I'd love to hear about that.