变换是指节点在XY平面上的变化。JavaFX支持四种基本转换,即-
缩放-增大或减小大小。
旋转-节点的坐标围绕固定点以一定角度移动。
平移 -节点在XY平面中的移动。
剪切-物体在固定方向上的位移,以使其形状倾斜。
JavaFX中的每个节点都包含一个可观察的列表,以保存要在节点上应用的所有转换。您可以使用getTransforms()方法获取此列表。您还可以将多个变换添加到节点。
以下JavaFX示例演示了向节点添加多个转换的过程。它包含2D几何形状和三个滑块,分别代表比例,旋转和平移变换。
import javafx.application.Application; import javafx.beans.value.ChangeListener; import javafx.beans.value.ObservableValue; import javafx.geometry.Orientation; import javafx.scene.Scene; import javafx.scene.control.Label; import javafx.scene.control.Slider; import javafx.scene.layout.BorderPane; import javafx.scene.layout.VBox; import javafx.scene.paint.Color; import javafx.scene.shape.Rectangle; import javafx.scene.transform.Rotate; import javafx.scene.transform.Scale; import javafx.scene.transform.Translate; import javafx.stage.Stage; public class MultipleTransformations extends Application { public void start(Stage stage) { //创建一个矩形 Rectangle rect = new Rectangle(300, 100, 75, 75); rect.setFill(Color.BLUEVIOLET); rect.setStrokeWidth(5.0); rect.setStroke(Color.BROWN); //创建旋转变换 Slider slider1 = new Slider(0, 360, 0); Rotate rotate = new Rotate(); //设置旋转的枢轴点 rotate.setPivotX(rect.getX()); rotate.setPivotY(rect.getY()); //设置旋转滑块 slider1.setShowTickLabels(true); slider1.setShowTickMarks(true); slider1.setMajorTickUnit(90); slider1.setBlockIncrement(10); slider1.setOrientation(Orientation.VERTICAL); slider1.valueProperty().addListener(new ChangeListener<Number>() { public void changed(ObservableValue <?extends Number>observable, Number oldValue, Number newValue){ //设置旋转角度 rotate.setAngle((double) newValue); } }); //创建翻译转换 Translate translate = new Translate(); //设置翻译滑块 Slider slider2 = new Slider(0, 200, 0); slider2.setOrientation(Orientation.VERTICAL); slider2.setShowTickLabels(true); slider2.setShowTickMarks(true); slider2.setMajorTickUnit(50); slider2.setBlockIncrement(50); slider2.valueProperty().addListener(new ChangeListener<Number>() { public void changed(ObservableValue <?extends Number>observable, Number oldValue, Number newValue){ translate.setX(25); translate.setY((double) newValue); translate.setZ(100); } }); //创建比例转换 Scale scale = new Scale(); scale.setPivotX(rect.getX()); scale.setPivotY(rect.getY()); //设置水平移动的滑块 Slider slider3 = new Slider(0, 2.5, 1); slider3.setShowTickLabels(true); slider3.setShowTickMarks(true); slider3.setMajorTickUnit(0.5); slider3.setBlockIncrement(0.1); slider3.valueProperty().addListener(new ChangeListener<Number>() { public void changed(ObservableValue <?extends Number>observable, Number oldValue, Number newValue){ scale.setX((double) newValue); scale.setY((double) newValue); } }); //将所有转换添加到节点 rect.getTransforms().addAll(translate, rotate, scale); //创建窗格 BorderPane pane = new BorderPane(); pane.setRight(new VBox(new Label("Rotate"), slider1)); pane.setCenter(rect); pane.setBottom(new VBox(new Label("Translate (Y axis)"), slider2)); pane.setLeft(new VBox(new Label("Scale"), slider3)); //准备场景 Scene scene = new Scene(pane, 595, 300); stage.setTitle("Multiple Transformations"); stage.setScene(scene); stage.show(); } public static void main(String args[]){ launch(args); } }
输出结果