0

好的,所以我在上一个基本的编程课程,我们必须制作一个包含所有不同窗格的边框窗格。当我尝试在中间放置一个带有“hello”按钮的常规窗格时,该按钮会放在边框窗格的顶部。所有其他窗格我使用的方法是制作 5 个按钮并随机插入一个单词并随机旋转它。我如何让窗格位于中心而不是顶部

    StackPane root = new StackPane();
    Button[] buttons = new Button[5];
    buttons = createButtons();
    root.getChildren().addAll(buttons);

    FlowPane flow = new FlowPane();
    Button[] buttons1 = new Button[5];
    buttons1 = createButtons();
    flow.getChildren().addAll(buttons1);

    HBox hbox= new HBox();
    Button[] buttons2 = new Button[5];
    buttons2 = createButtons();
    hbox.getChildren().addAll(buttons2); 

    VBox vbox = new VBox();
    Button[] buttons3 = new Button[5];
    buttons3 = createButtons();
    vbox.getChildren().addAll(buttons3);

    Pane pane = new Pane();
    Button btn = new Button();
    btn.setText("Hello");
    pane.getChildren().add(btn);

    BorderPane border = new BorderPane();
    border.setBottom(hbox);
    border.setLeft(root);
    border.setRight(vbox);
    border.setTop(flow);
    border.setCenter(pane);
    Scene scene = new Scene(border, 500, 500);

    primaryStage.setTitle("Buttons");
    primaryStage.setScene(scene);
    primaryStage.show();
}
4

1 回答 1

0

您应该添加背景颜色以进行识别,例如通过 setStyle("-fx-background-color:black)。这样您就可以看到每个窗格的布局方式。

例子:

public class BindIt extends Application {

    @Override
    public void start(Stage primaryStage) {

        StackPane root = new StackPane();
        root.setStyle("-fx-background-color:red");
        Button[] buttons = new Button[5];
        buttons = createButtons();
        root.getChildren().addAll(buttons);

        FlowPane flow = new FlowPane();
        flow.setStyle("-fx-background-color:blue");
        Button[] buttons1 = new Button[5];
        buttons1 = createButtons();
        flow.getChildren().addAll(buttons1);

        HBox hbox= new HBox();
        hbox.setStyle("-fx-background-color:green");
        Button[] buttons2 = new Button[5];
        buttons2 = createButtons();
        hbox.getChildren().addAll(buttons2); 

        VBox vbox = new VBox();
        vbox.setStyle("-fx-background-color:yellow");
        Button[] buttons3 = new Button[5];
        buttons3 = createButtons();
        vbox.getChildren().addAll(buttons3);

        Pane pane = new Pane();
        pane.setStyle("-fx-background-color:cyan");
        Button btn = new Button();
        btn.setText("Hello");
        pane.getChildren().add(btn);

        BorderPane border = new BorderPane();
        border.setStyle("-fx-background-color:black");
        border.setBottom(hbox);
        border.setLeft(root);
        border.setRight(vbox);
        border.setTop(flow);
        border.setCenter(pane);
        Scene scene = new Scene(border, 500, 500);

        primaryStage.setTitle("Buttons");
        primaryStage.setScene(scene);
        primaryStage.show();

    }

    private Button[] createButtons() {
        return new Button[] { new Button( "Button") };
    }

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

}

它给你这个:

在此处输入图像描述

现在您看到中心窗格位于中心并填充中心。问题是按钮不在中心。简单的解决方案是只使用 StackPane 作为中心窗格:

StackPane pane = new StackPane();

另一种解决方案是将按钮重新定位到中心窗格的中心。但是你必须考虑调整父母的大小。

于 2015-03-22T06:10:11.833 回答