public final class Timeline
  Comment     Returned-by     Constructor-argument     Method-argument     Field-type     Type-bound     Links  

A Timeline can be used to define a free form animation of any javafx.beans.value.WritableValue, e.g. all JavaFX Properties.

A Timeline, defined by one or more KeyFrames, processes individual KeyFrame sequentially, in the order specified by KeyFrame.time. The animated properties, defined as key values in KeyFrame.values, are interpolated to/from the targeted key values at the specified time of the KeyFrame to Timeline's initial position, depends on Timeline's direction.

Timeline processes individual KeyFrame at or after specified time interval elapsed, it does not guarantee the timing when KeyFrame is processed.

The cycleDurationProperty() will be set to the largest time value of Timeline's keyFrames.

If a KeyFrame is not provided for the time==0s instant, one will be synthesized using the target values that are current at the time play() or playFromStart() is called.

It is not possible to change the keyFrames of a running Timeline. If the value of keyFrames is changed for a running Timeline, it has to be stopped and started again to pick up the new value.

A simple Timeline can be created like this:


 final Timeline timeline = new Timeline();
 timeline.setCycleCount(2);
 timeline.setAutoReverse(true);
 timeline.getKeyFrames().add(new KeyFrame(Duration.millis(5000),
   new KeyValue (node.translateXProperty(), 25)));
 timeline.play();
 

This Timeline will run for 10s, animating the node by x axis to value 25 and then back to 0 on the second cycle.

Warning : A running Timeline is being referenced from the FX runtime. Infinite Timeline might result in a memory leak if not stopped properly. All the objects with animated properties would not be garbage collected.

extends Animation

See also:
Animation, KeyFrame, KeyValue

Since:  JavaFX 2.0