SpriteKit+Spring is a set of extensions to perform spring animations with SpriteKit.
In iOS 7, Apple introduced spring animations in UIKit by adding a new animation method on UIView (see WWDC video and UIView documentation).
This library replicates this feature by adding a spring variant to most factory methods of SKAction. The parameters usingSpringWithDamping:
and initialSpringVelocity:
have the same meaning as their UIKit counterpart. See below for examples.
let move = SKAction.moveByX(0, y: 200,
duration: 5, delay: 5,
usingSpringWithDamping: 0.2, initialSpringVelocity: 0)
node.runAction(move)
let scale = SKAction.scaleXTo(2, y: 0.5,
duration: 5, delay: 5,
usingSpringWithDamping: 0.2, initialSpringVelocity: 0)
node.runAction(scale)
let rotate = SKAction.rotateByAngle(CGFloat(M_PI/2),
duration: 5, delay: 5,
usingSpringWithDamping: 0.2, initialSpringVelocity: 0)
node.runAction(rotate)
- Because they use
customActionWithDuration:actionBlock:
, none of these actions is reversible (the reverse action performs the same animation). - All these factory methods are based on the lower level
animateKeyPath:byValue:duration:delay:usingSpringWithDamping:initialSpringVelocity:
andanimateKeyPath:toValue:duration:delay:usingSpringWithDamping:initialSpringVelocity:
methods, which can animate any CGFloat key path. If you have a SKNode subclass with a fancy CGFloat property that you'd like to animate, feel free to use these methods!
SpriteKit+Spring is released under the Apache 2 license. See LICENSE for details.