Can't center nodes within a border pane

6.6k Views Asked by At

I can't for the life of me figure out why I can't center a VBox within one of the sections within a border pane.

@Override
public void start(Stage primaryStage) throws Exception{
    BorderPane root = new BorderPane();
    Scene scene = new Scene(root, 960, 600);
    primaryStage.setScene(scene);
    primaryStage.setTitle("Test application");
    primaryStage.setFullScreen(true);
    primaryStage.setFullScreenExitHint("Press escape to exit fullscreen");
    primaryStage.show();
    javafx.scene.image.Image icon = new Image("sample/Riverviewcrest.png");
    primaryStage.getIcons().add(icon);

    Pane paneleft = new Pane();
    Pane paneright = new Pane();
    Pane panecenter = new Pane();
    Pane panetop = new Pane();
    Pane panebottom = new Pane();

    paneleft.setPrefWidth(100);
    paneright.setPrefWidth(100);
    panetop.setPrefHeight(100);
    panebottom.setPrefHeight(100);

    panecenter.setStyle("-fx-background-color: #0053A8");

    root.setLeft(paneleft);
    root.setRight(paneright);
    root.setCenter(panecenter);
    root.setTop(panetop);
    root.setBottom(panebottom);


    Text test = new Text("Hello");
    Text test2 = new Text("Hello");
    Text test3 = new Text("Hello");
    Text test4 = new Text("Hello");
    VBox box = new VBox();
    box.getChildren().addAll(test, test2, test3, test4);
    panecenter.getChildren().add(box);
    root.setAlignment(box, Pos.CENTER);
}

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

The aim is to have the text centered within the center part of the border pane. Thanks for any and all help!

2

There are 2 best solutions below

2
On BEST ANSWER

No need to have the panecenter at all. Simply set box to the center property of your BorderPane and center it:

box.setAlignment(Pos.CENTER);
root.setCenter(box);

You don't need paneleft, paneright, panetop or panebottom either.

0
On

paneCenter is just a pane like everything else. So paneCenter gets centered, not the VBox.

You can use a StackPane and adapt the VBox's alignment like this:

import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.Pane;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import javafx.scene.text.Text;
import javafx.stage.Stage;

public class Main extends Application {
    @Override
    public void start(Stage primaryStage) throws Exception{
        BorderPane root = new BorderPane();
        Scene scene = new Scene(root, 960, 600);
        primaryStage.setScene(scene);
        primaryStage.setTitle("Test application");
        primaryStage.show();

        Pane paneleft = new Pane();
        Pane paneright = new Pane();
        StackPane panecenter = new StackPane();
        Pane panetop = new Pane();
        Pane panebottom = new Pane();

        paneleft.setPrefWidth(100);
        paneright.setPrefWidth(100);
        panetop.setPrefHeight(100);
        panebottom.setPrefHeight(100);

        panecenter.setStyle("-fx-background-color: #0053A8");

        root.setLeft(paneleft);
        root.setRight(paneright);
        root.setCenter(panecenter);
        root.setTop(panetop);
        root.setBottom(panebottom);


        Text test = new Text("Hello");
        Text test2 = new Text("Hello");
        Text test3 = new Text("Hello");
        Text test4 = new Text("Hello");
        VBox box = new VBox();
        box.setAlignment(Pos.CENTER);
        box.getChildren().addAll(test, test2, test3, test4);
        panecenter.getChildren().add(box);
    }

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

Or you could drop the panecenter and use the VBox instead.

import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.Pane;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import javafx.scene.text.Text;
import javafx.stage.Stage;

public class Main extends Application {
    @Override
    public void start(Stage primaryStage) throws Exception{
        BorderPane root = new BorderPane();
        Scene scene = new Scene(root, 960, 600);
        primaryStage.setScene(scene);
        primaryStage.setTitle("Test application");
        primaryStage.show();

        Pane paneleft = new Pane();
        Pane paneright = new Pane();
        StackPane panecenter = new StackPane();
        Pane panetop = new Pane();
        Pane panebottom = new Pane();

        paneleft.setPrefWidth(100);
        paneright.setPrefWidth(100);
        panetop.setPrefHeight(100);
        panebottom.setPrefHeight(100);

        panecenter.setStyle("-fx-background-color: #0053A8");

        root.setLeft(paneleft);
        root.setRight(paneright);
        root.setTop(panetop);
        root.setBottom(panebottom);


        Text test = new Text("Hello");
        Text test2 = new Text("Hello");
        Text test3 = new Text("Hello");
        Text test4 = new Text("Hello");
        VBox box = new VBox();
        box.setAlignment(Pos.CENTER);
        box.getChildren().addAll(test, test2, test3, test4);
        root.setCenter(box);
    }

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