在不移动原点的情况下缩放JavaFX形状 [英] JavaFX Scaling Shape without moving the origin
本文介绍了在不移动原点的情况下缩放JavaFX形状的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我的形状的缩放功能有问题。我想使用一个由我自己绘制的坐标系,其中包含一些形状。这些形状需要缩放功能。在缩放形状之后,它们会移动,因为缩放发生在每个形状的中心。为了对这一运动做出反应,我重新计算了原点。但如果我多次缩放,形状仍然偏离原点。我不知道为什么。有人能解释这种行为吗? 此外,我尝试重新计算笔划宽度以保持1px。
谢谢!
我的代码:
import javafx.application.Application;
import javafx.event.EventHandler;
import javafx.geometry.Bounds;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.input.ScrollEvent;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Line;
import javafx.scene.shape.Polyline;
import javafx.stage.Stage;
public class ScaleTest extends Application {
public static void main(String[] args) {
launch(args);
}
@Override
public void start(Stage stage) throws Exception {
Pane root = new Pane();
Scene scene = new Scene(root, 800, 600, Color.WHITE);
stage.setScene(scene);
Polyline line1 = new Polyline(new double[] { 50, 50, 50, 150, 150, 150,
150, 50, 50, 50 });
line1.setStrokeWidth(1);
Group polylines = new Group();
polylines.getChildren().add(line1);
Line xAxis = new Line(0, 50, 800, 50);
Line yAxis = new Line(50, 0, 50, 800);
root.setScaleY(-1);
root.getChildren().addAll(xAxis, yAxis);
root.getChildren().add(polylines);
scene.setOnScroll(new EventHandler<ScrollEvent>() {
@Override
public void handle(ScrollEvent event) {
double scale = 0;
if (event.getDeltaY() < 0) {
scale = -0.1;
} else {
scale = 0.1;
}
Bounds beforeScaling = polylines.getBoundsInParent();
polylines.setScaleX(polylines.getScaleX() + scale);
polylines.setScaleY(polylines.getScaleY() + scale);
Bounds afterScaling = polylines.getBoundsInParent();
polylines.setTranslateX(polylines.getTranslateX()
+ beforeScaling.getMinX() - afterScaling.getMinX());
polylines.setTranslateY(polylines.getTranslateY()
+ beforeScaling.getMinY() - afterScaling.getMinY());
//optional
line1.setStrokeWidth(1/polylines.getScaleX());
}
});
stage.show();
}
}
推荐答案
我不确定它为什么会"漂移"--可能只是累积了舍入误差。无论如何,更简单的方法是使用Scale
转换。使用此选项,您可以指定缩放时所围绕的"轴心点"。
import javafx.application.Application;
import javafx.event.EventHandler;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.input.ScrollEvent;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Line;
import javafx.scene.shape.Polyline;
import javafx.scene.transform.Scale;
import javafx.stage.Stage;
public class ScaleTest extends Application {
public static void main(String[] args) {
launch(args);
}
@Override
public void start(Stage stage) throws Exception {
Pane root = new Pane();
Scene scene = new Scene(root, 800, 600, Color.WHITE);
stage.setScene(scene);
Polyline line1 = new Polyline(new double[] { 50, 50, 50, 150, 150, 150,
150, 50, 50, 50 });
line1.setStrokeWidth(1);
Group polylines = new Group();
polylines.getChildren().add(line1);
Line xAxis = new Line(0, 50, 800, 50);
Line yAxis = new Line(50, 0, 50, 800);
root.setScaleY(-1);
root.getChildren().addAll(xAxis, yAxis);
root.getChildren().add(polylines);
Scale scale = new Scale();
scale.setPivotX(50);
scale.setPivotY(50);
polylines.getTransforms().add(scale);
scene.setOnScroll(new EventHandler<ScrollEvent>() {
@Override
public void handle(ScrollEvent event) {
double scaleDelta = 0;
if (event.getDeltaY() < 0) {
scaleDelta = -0.1;
} else {
scaleDelta = 0.1;
}
scale.setX(scale.getX() + scaleDelta);
scale.setY(scale.getY() + scaleDelta);
//optional
line1.setStrokeWidth(1/scale.getX());
}
});
stage.show();
}
}
这篇关于在不移动原点的情况下缩放JavaFX形状的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文