如何在窗格javafx中居中节点

dar*_*eck 12 javafx center pane javafx-2

如何创建一个窗格并将一个孩子Node放在中心?

让说的Pane500通过500NodeImageView一个200200 Image

ImageView view = new ImageView();

Image img = new Image("test.png");
view.setImage(img);
Pane pane = new Pane();
pane.setMinWidth(500);
pane.setMinHeight(500);
pane.getChildren().add(view);
Run Code Online (Sandbox Code Playgroud)

小智 19

你有2个选择:

  1. 例如使用StackPane而不是Pane(因为你可以使用Pos)

    StackPane p = new StackPane();
    p.setPrefSize(700,700); //set a default size for your stackpane
    Image img = new Image("test.png"); //create an image
    ImageView v = new ImageView(img); //create an imageView and pass the image 
    
    p.getChildren().add(v); //add imageView to stackPane
    StackPane.setAlignment(v,Pos.CENTER_LEFT); //set it to the Center Left(by default it's on the center)
    stage.setScene(new Scene(p));
    stage.show();
    
    Run Code Online (Sandbox Code Playgroud)
  2. 您可以使用JavaFx Scene Builder,它是JavaFx的可视化布局工具.例如,如果我想创建一个Hbox布局:

    <?xml version="1.0" encoding="UTF-8"?>
    
        <?import java.lang.*?>
        <?import java.net.*?>
        <?import java.util.*?>
        <?import javafx.geometry.*?>
        <?import javafx.scene.*?>
        <?import javafx.scene.control.*?>
        <?import javafx.scene.effect.*?>
        <?import javafx.scene.image.*?>
        <?import javafx.scene.layout.*?>
        <?import javafx.scene.shape.*?>
        <?import javafx.scene.text.*?>
    
        <HBox alignment="CENTER" prefHeight="369.0" prefWidth="425.0" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/2.2" >
            <children>
                <ImageView fitHeight="150.0" fitWidth="200.0" pickOnBounds="true" preserveRatio="true" x="0.0" HBox.hgrow="NEVER">
                    <image>
                        <Image url="@../yourImg.png" />
                    </image>
                </ImageView>
            </children>
        </HBox>
    
    Run Code Online (Sandbox Code Playgroud)

    将其保存myLayout.fxml为主类,并在代码中添加以下内容:

    Hbox root = FXMLLoader.load(getClass().getResource("myLayout.fxml"));
    Scene scene = new Scene(root);
    stage.setScene(scene);
    stage.show();
    
    Run Code Online (Sandbox Code Playgroud)

  • 谢谢。如果它是一个没有首选大小的 anchorPane 会发生什么。我试图将 stackPane 添加到 Anchor Pane。但是,如果没有设置首选大小,则居中将不起作用。在我的示例中,锚定窗格可以调整大小,因为左、右、上和下是可以打开的选项卡,并且可以更改中心锚定窗格的大小。 (2认同)

Eng*_*uad 7

我通常使用以下方法来中心节点/窗格:

<VBox alignment="CENTER">
    <HBox alignment="CENTER">
        <!-- your node/pane -->
    </HBox>
</VBox>
Run Code Online (Sandbox Code Playgroud)