我正在尝试创建基于节点的图形界面,àlablender或unreal engine。我尝试过使用JavaFx,但是在连接节点方面遇到了困难 - 我感觉我正在用错误的技术解决问题。
我已经检查了this类似问题,但答案似乎是基于OOP原则而不是图形本身。
解决此问题的最简单方法是什么?有任何想法吗?提前谢谢。
答案 0 :(得分:1)
如果您只想将某些节点与线连接起来,您可能只需要将它们添加到窗格中,其中一条线的起点和终点绑定到节点的坐标。
这是一个简单的例子,可以在窗格周围拖动几个矩形,线条与它们保持连接。显然你可以改进这一点,所以连接线从矩形的适当面开始和结束等,但它显示了基本的想法。
import javafx.application.Application;
import javafx.beans.binding.Bindings;
import javafx.scene.Node;
import javafx.scene.Scene;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Line;
import javafx.scene.shape.Rectangle;
import javafx.stage.Stage;
public class ConnectedBoxes extends Application {
@Override
public void start(Stage primaryStage) {
Rectangle startBox = createDraggableBox(50, 50);
startBox.setX(50);
startBox.setY(50);
Rectangle endBox = createDraggableBox(50, 50);
endBox.setX(350);
endBox.setY(200);
Line connector = createConnector(startBox, endBox);
Pane pane = new Pane(startBox, endBox, connector);
Scene scene = new Scene(pane, 600, 600);
primaryStage.setScene(scene);
primaryStage.show();
}
private Line createConnector(Node start, Node end) {
Line l = new Line();
l.startXProperty().bind(Bindings.createDoubleBinding(
() -> start.getBoundsInParent().getMaxX(),
start.boundsInParentProperty()));
l.startYProperty().bind(Bindings.createDoubleBinding(
() -> start.getBoundsInParent().getMinY() + start.getBoundsInParent().getHeight() / 2,
start.boundsInParentProperty()));
l.endXProperty().bind(Bindings.createDoubleBinding(
() -> end.getBoundsInParent().getMinX(),
end.boundsInParentProperty()));
l.endYProperty().bind(Bindings.createDoubleBinding(
() -> end.getBoundsInParent().getMinY() + end.getBoundsInParent().getHeight() / 2,
end.boundsInParentProperty()));
return l ;
}
public Rectangle createDraggableBox(int width, int height) {
Rectangle r = new Rectangle(width, height);
r.setFill(Color.CORAL);
DragDelta delta = new DragDelta();
r.setOnMousePressed(e -> {
delta.x = e.getX();
delta.y = e.getY();
});
r.setOnMouseDragged(e -> {
double deltaX = e.getX() - delta.x ;
double deltaY = e.getY() - delta.y ;
r.setX(r.getX() + deltaX);
r.setY(r.getY() + deltaY);
delta.x = e.getX();
delta.y = e.getY();
});
return r ;
}
class DragDelta { double x,y ;}
public static void main(String[] args) {
launch(args);
}
}