gpt4 book ai didi

java - 无法使用 JavaFX 将矩形拖放到所需位置

转载 作者:行者123 更新时间:2023-12-02 05:00:30 44 4
gpt4 key购买 nike

我正在尝试使用 JavaFX 实现完整的按下-拖动-释放手势。我想将一个矩形从一个垂直框拖动到另一个垂直框。在目标 VBox 上发生的 MOUSE_DRAG_RELEASED 事件中,我尝试将拖动的矩形添加为目标 V​​Box 的子级。

问题是,当我在目标 VBox 上释放鼠标时,矩形不会进入 VBox 内的预期位置,而是始终向右偏移固定距离。

public class DragFromOneVBoxToAnother extends Application {
private Disk sourceDisk = new Disk();
private VBox targetVBox = new VBox();

public static void main(String[] args) {
Application.launch(args);
}

@Override
public void start(Stage stage) {
// Build the UI
GridPane root = getUI();

// Add the event handlers
this.addEventHandlers();

Scene scene = new Scene(root, 800, 600);
stage.setScene(scene);
stage.show();
}

private GridPane getUI() {
GridPane pane = new GridPane();
VBox sourceVBox = new VBox();

sourceDisk.setWidth(90);
sourceDisk.setHeight(20);

sourceVBox.setStyle(" -fx-border-color:red; -fx-border-width: 1; -fx-border-style: solid;");
targetVBox.setStyle(" -fx-border-color:green; -fx-border-width: 1; -fx-border-style: solid;");

sourceVBox.getChildren().add(sourceDisk);
targetVBox.getChildren().add(new Rectangle(200, 20));

pane.setHgap(200);
pane.addColumn(0, sourceVBox);
pane.addColumn(1, targetVBox);
pane.setPadding(new Insets(200, 100, 200, 100));

return pane;
}

private void addEventHandlers() {
sourceDisk.setOnMouseEntered(event -> sourceDisk.setCursor(Cursor.HAND));

sourceDisk.setOnMousePressed(event -> {
sourceDisk.setOrgSceneX(event.getSceneX());
sourceDisk.setOrgSceneY(event.getSceneY());
sourceDisk.setOrgTranslateX(sourceDisk.getTranslateX());
sourceDisk.setOrgTranslateY(sourceDisk.getTranslateY());

sourceDisk.setMouseTransparent(true);
sourceDisk.setCursor(Cursor.CLOSED_HAND);
});

sourceDisk.setOnDragDetected(event -> sourceDisk.startFullDrag());

sourceDisk.setOnMouseDragged(event -> {
double offsetX = event.getSceneX() - sourceDisk.getOrgSceneX();
double offsetY = event.getSceneY() - sourceDisk.getOrgSceneY();
double newTranslateX = sourceDisk.getOrgTranslateX() + offsetX;
double newTranslateY = sourceDisk.getOrgTranslateY() + offsetY;

sourceDisk.setTranslateX(newTranslateX);
sourceDisk.setTranslateY(newTranslateY);
});

sourceDisk.setOnMouseReleased(event -> {
sourceDisk.setMouseTransparent(false);
sourceDisk.setCursor(Cursor.DEFAULT);
});

targetVBox.setOnMouseDragReleased(event ->
targetVBox.getChildren().add(sourceDisk));
}

private class Disk extends Rectangle {
private double orgSceneX;
private double orgSceneY;
private double orgTranslateX;
private double orgTranslateY;

// below, the getters and setters for all the instance variables
// were removed for brevity
}

我发现,尽管拖动矩形的视觉表示在放下时似乎发生了偏移,但子项似乎实际上被添加到了目标 VBox(这可以看出,因为 VBox 的边框在MOUSE_DRAG_RELEASED 事件)。可能是什么问题?

最佳答案

在鼠标拖动手势期间,您可以修改节点的 translateX/translateY 属性。这会导致拖动的节点从新父节点通过此变换放置它的位置发生偏移。您需要重置这些值才能将节点正确添加到 VBox 的底部:

targetVBox.setOnMouseDragReleased(event -> {
targetVBox.getChildren().add(sourceDisk);

// reset translate values
sourceDisk.setTranslateX(0);
sourceDisk.setTranslateY(0);
});

关于java - 无法使用 JavaFX 将矩形拖放到所需位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56388840/

44 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com