JavaFX - Animationen
Im Allgemeinen bedeutet das Animieren eines Objekts, dass durch schnelle Anzeige eine Illusion seiner Bewegung erzeugt wird. In JavaFX kann ein Knoten animiert werden, indem seine Eigenschaft im Laufe der Zeit geändert wird. JavaFX bietet ein Paket mit dem Namenjavafx.animation. Dieses Paket enthält Klassen, mit denen die Knoten animiert werden. Animation ist die Basisklasse all dieser Klassen.
Mit JavaFX können Sie Animationen (Übergänge) wie z Fade Transition, Fill Transition, Rotate Transition, Scale Transition, Stroke Transition, Translate Transition, Path Transition, Sequential Transition, Pause Transition, Parallel Transition, usw.
Alle diese Übergänge werden durch einzelne Klassen im Paket dargestellt javafx.animation.
Um eine bestimmte Animation auf einen Knoten anzuwenden, müssen Sie die folgenden Schritte ausführen:
Erstellen Sie einen erforderlichen Knoten mit der entsprechenden Klasse.
Instanziieren Sie die jeweilige Übergangsklasse (Animation), die angewendet werden soll
Legen Sie die Eigenschaften des Übergangs und fest
Spielen Sie zum Schluss den Übergang mit dem play() Methode der Animation Klasse.
In diesem Kapitel werden Beispiele für grundlegende Übergänge (Rotation, Skalierung, Übersetzung) erläutert.
Übergang drehen
Das folgende Programm demonstriert Rotate Transition in JavaFX. Speichern Sie diesen Code in einer Datei mit dem NamenRotateTransitionExample.java.
import javafx.animation.RotateTransition;
import javafx.application.Application;
import static javafx.application.Application.launch;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.paint.Color;
import javafx.scene.shape.Polygon;
import javafx.stage.Stage;
import javafx.util.Duration;
public class RotateTransitionExample extends Application {
@Override
public void start(Stage stage) {
//Creating a hexagon
Polygon hexagon = new Polygon();
//Adding coordinates to the hexagon
hexagon.getPoints().addAll(new Double[]{
200.0, 50.0,
400.0, 50.0,
450.0, 150.0,
400.0, 250.0,
200.0, 250.0,
150.0, 150.0,
});
//Setting the fill color for the hexagon
hexagon.setFill(Color.BLUE);
//Creating a rotate transition
RotateTransition rotateTransition = new RotateTransition();
//Setting the duration for the transition
rotateTransition.setDuration(Duration.millis(1000));
//Setting the node for the transition
rotateTransition.setNode(hexagon);
//Setting the angle of the rotation
rotateTransition.setByAngle(360);
//Setting the cycle count for the transition
rotateTransition.setCycleCount(50);
//Setting auto reverse value to false
rotateTransition.setAutoReverse(false);
//Playing the animation
rotateTransition.play();
//Creating a Group object
Group root = new Group(hexagon);
//Creating a scene object
Scene scene = new Scene(root, 600, 300);
//Setting title to the Stage
stage.setTitle("Rotate transition example ");
//Adding scene to the stage
stage.setScene(scene);
//Displaying the contents of the stage
stage.show();
}
public static void main(String args[]){
launch(args);
}
}
Kompilieren Sie die gespeicherte Java-Datei und führen Sie sie mit den folgenden Befehlen an der Eingabeaufforderung aus.
javac RotateTransitionExample.java
java RotateTransitionExample
Bei der Ausführung generiert das obige Programm ein JavaFX-Fenster wie unten gezeigt.
Skalenübergang
Das folgende Programm demonstriert Scale Transition in JavaFX. Speichern Sie diesen Code in einer Datei mit dem NamenScaleTransitionExample.java.
import javafx.animation.ScaleTransition;
import javafx.application.Application;
import static javafx.application.Application.launch;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;
import javafx.util.Duration;
public class ScaleTransitionExample extends Application {
@Override
public void start(Stage stage) {
//Drawing a Circle
Circle circle = new Circle();
//Setting the position of the circle
circle.setCenterX(300.0f);
circle.setCenterY(135.0f);
//Setting the radius of the circle
circle.setRadius(50.0f);
//Setting the color of the circle
circle.setFill(Color.BROWN);
//Setting the stroke width of the circle
circle.setStrokeWidth(20);
//Creating scale Transition
ScaleTransition scaleTransition = new ScaleTransition();
//Setting the duration for the transition
scaleTransition.setDuration(Duration.millis(1000));
//Setting the node for the transition
scaleTransition.setNode(circle);
//Setting the dimensions for scaling
scaleTransition.setByY(1.5);
scaleTransition.setByX(1.5);
//Setting the cycle count for the translation
scaleTransition.setCycleCount(50);
//Setting auto reverse value to true
scaleTransition.setAutoReverse(false);
//Playing the animation
scaleTransition.play();
//Creating a Group object
Group root = new Group(circle);
//Creating a scene object
Scene scene = new Scene(root, 600, 300);
//Setting title to the Stage
stage.setTitle("Scale transition example");
//Adding scene to the stage
stage.setScene(scene);
//Displaying the contents of the stage
stage.show();
}
public static void main(String args[]){
launch(args);
}
}
Kompilieren Sie die gespeicherte Java-Datei und führen Sie sie mit den folgenden Befehlen an der Eingabeaufforderung aus.
javac ScaleTransitionExample.java
java ScaleTransitionExample
Bei der Ausführung generiert das obige Programm ein JavaFX-Fenster wie unten gezeigt.
Übergang übersetzen
Das folgende Programm demonstriert den Übersetzungsübergang in JavaFX. Speichern Sie diesen Code in einer Datei mit dem NamenTranslateTransitionExample.java.
import javafx.animation.TranslateTransition;
import javafx.application.Application;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;
import javafx.util.Duration;
public class TranslateTransitionExample extends Application {
@Override
public void start(Stage stage) {
//Drawing a Circle
Circle circle = new Circle();
//Setting the position of the circle
circle.setCenterX(150.0f);
circle.setCenterY(135.0f);
//Setting the radius of the circle
circle.setRadius(100.0f);
//Setting the color of the circle
circle.setFill(Color.BROWN);
//Setting the stroke width of the circle
circle.setStrokeWidth(20);
//Creating Translate Transition
TranslateTransition translateTransition = new TranslateTransition();
//Setting the duration of the transition
translateTransition.setDuration(Duration.millis(1000));
//Setting the node for the transition
translateTransition.setNode(circle);
//Setting the value of the transition along the x axis.
translateTransition.setByX(300);
//Setting the cycle count for the transition
translateTransition.setCycleCount(50);
//Setting auto reverse value to false
translateTransition.setAutoReverse(false);
//Playing the animation
translateTransition.play();
//Creating a Group object
Group root = new Group(circle);
//Creating a scene object
Scene scene = new Scene(root, 600, 300);
//Setting title to the Stage
stage.setTitle("Translate transition example");
//Adding scene to the stage
stage.setScene(scene);
//Displaying the contents of the stage
stage.show();
}
public static void main(String args[]){
launch(args);
}
}
Kompilieren Sie die gespeicherte Java-Datei und führen Sie sie mit den folgenden Befehlen an der Eingabeaufforderung aus.
javac TranslateTransitionExample.java
java TranslateTransitionExample
Bei der Ausführung generiert das obige Programm ein JavaFX-Fenster wie unten gezeigt.
Darüber hinaus bietet JavaFX Klassen, um mehr Übergänge auf Knoten anzuwenden. Im Folgenden sind die anderen Arten von Übergängen aufgeführt, die von JavaFX unterstützt werden.
Übergänge, die sich auf die Attribute der Knoten Fade, Fill, Stroke auswirken
Übergang, der mehr als einen grundlegenden Übergang umfasst: Sequentiell, Parallel, Pause
Übergang, der das Objekt entlang des angegebenen Pfads übersetzt. Pfadübergang