package src.com.fxexperience.javafx.animation;
import javafx.animation.KeyFrame;
import javafx.animation.KeyValue;
import javafx.animation.TimelineBuilder;
import javafx.scene.Node;
import javafx.util.Duration;
/**
* Animate a swing effect on the given node
*
* Port of Swing from Animate.css http://daneden.me/animate by Dan Eden
*
* {@literal @}keyframes swing { 20% { transform: rotate(15deg); } 40% {
* transform: rotate(-10deg); } 60% { transform: rotate(5deg); } 80% {
* transform: rotate(-5deg); } 100% { transform: rotate(0deg); } }
*
* @author Jasper Potts
*/
public class SwingTransition extends CachedTimelineTransition {
/**
* Create new SwingTransition
*
* @param node
* The node to affect
*/
public SwingTransition(final Node node) {
super(node, TimelineBuilder
.create()
.keyFrames(
new KeyFrame(Duration.millis(0), new KeyValue(
node.rotateProperty(), 0, WEB_EASE)),
new KeyFrame(Duration.millis(200), new KeyValue(node
.rotateProperty(), 15, WEB_EASE)),
new KeyFrame(Duration.millis(400), new KeyValue(node
.rotateProperty(), -10, WEB_EASE)),
new KeyFrame(Duration.millis(600), new KeyValue(node
.rotateProperty(), 5, WEB_EASE)),
new KeyFrame(Duration.millis(800), new KeyValue(node
.rotateProperty(), -5, WEB_EASE)),
new KeyFrame(Duration.millis(1000), new KeyValue(node
.rotateProperty(), 0, WEB_EASE))).build());
setCycleDuration(Duration.seconds(1));
setDelay(Duration.seconds(0.2));
}
}