Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

JavaFx GridPane - how to center elements

I have a GridPane filled with 1-letter-labels.

Here is an image:

image

Here is the code:

int charSpacing = 1;
int charsInWidth = 28;
int charsInHeight = 16;

double charWidth = 15;
double charHeight = 20;

GridPane gp = new GridPane();
gp.setAlignment(Pos.CENTER);

Label[] tmp = new Label[charsInHeight*charsInWidth];

String text = "W";
int currArrPos = 0;

for(int y = 0; y < charsInHeight; y++) {
    HBox hbox = new HBox(charSpacing);

    for(int x = 0; x < charsInWidth; x++) {
        tmp[currArrPos] = new Label(text);
        tmp[currArrPos].setTextFill(Paint.valueOf("white"));

        tmp[currArrPos].setMinHeight(charHeight);
        tmp[currArrPos].setMinWidth(charWidth);
        tmp[currArrPos].setMaxHeight(charHeight);
        tmp[currArrPos].setMaxWidth(charWidth);

        tmp[currArrPos].setStyle("-fx-border-color: white;");
        hbox.getChildren().add(tmp[currArrPos++]);

        if(x%2 == 0){
            text = "I";
        } else{
            text = "W";
        }
    }
    gp.add(hbox, 1, y);
}
guiDisplay.getChildren().add(gp);

How can I center the characters?

I have put them in a HBox and gave them spacing. I tried to make the textAlignment of the label to CENTER, but that doesn't work of course.

I tried this also:

gp.setAlignment(Pos.CENTER);

Has anybody an idea? Thanks!

like image 269
immerhart Avatar asked Oct 10 '12 09:10

immerhart


1 Answers

You can use the setAligment(Pos.CENTER) property of your element-

or you can define a contraint to the GridPane that contains the elements

<columnConstraints>
    <ColumnConstraints halignment="CENTER" />
</columnConstraints>

Example:

<?import javafx.geometry.Insets?>
<?import javafx.scene.layout.GridPane?>
<?import javafx.scene.control.Label?>
<?import javafx.scene.layout.ColumnConstraints?>

<GridPane fx:controller="app.graphics.Controller"
          xmlns:fx="http://javafx.com/fxml" alignment="center" hgap="10" vgap="10">
    <columnConstraints>
        <ColumnConstraints halignment="CENTER" />
    </columnConstraints>
</GridPane>
like image 135
Jorgesys Avatar answered Sep 24 '22 13:09

Jorgesys