49

我有一个只有一个 FXML 文件的 JavaFX 应用程序。在这个文件中,我有一个 AnchorPane,里面有一个 StackPane。这是屏幕截图:

我的面板应用程序内的面板

当我启动这个应用程序时,我想使用 AnchorPane 自动调整 StackPane 的大小。因此; StackPane 将自动获取当前可用的宽度和高度。在我调整应用程序大小的那一刻,AnchorPane 正在自动调整大小,但 StackPane 保持其固定大小。

如何自动调整 StackPane 的大小并使其在其父面板内完全拉伸?

我的代码

主.java

package app;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class Main extends Application {

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

  @Override
  public void start(Stage stage) throws Exception {
      Parent root = FXMLLoader.load(getClass().getResource("Main.fxml"));
      Scene scene = new Scene(root,800,600);
      scene.getStylesheets().add(this.getClass().getResource("/app/style1.css").toExternalForm());
      stage.setScene(scene);
      stage.show();
  }
}

主控制器.java

package app;

import java.net.URL;
import java.util.ResourceBundle;
import javafx.fxml.FXML;
import javafx.fxml.Initializable;
import javafx.scene.layout.AnchorPane;
import javafx.scene.layout.StackPane;

public class MainController implements Initializable {

   @FXML
   private AnchorPane anchorPane;
   @FXML
   private StackPane stackPane;

   @Override
   public void initialize(URL url, ResourceBundle rb) {
     stackPane.setPrefSize(anchorPane.getPrefWidth(), anchorPane.getPrefHeight()); //didn't work
   }    
}

主文件

<?xml version="1.0" encoding="UTF-8"?>
<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>

<AnchorPane fx:id="anchorPane" xmlns:fx="http://javafx.com/fxml" fx:controller="app.MainController">
    <StackPane fx:id="stackPane" ></StackPane>
</AnchorPane>

样式1.css

#anchorPane { 
    -fx-border-width: 2px;
    -fx-border-color: chartreuse;
}
#stackPane {
    -fx-border-width: 2px;
    -fx-border-color: red;

    /* didn't work */
   -fx-hgap: 100%;
   -fx-vgap: 100%;
}
4

6 回答 6

84

经过数小时的搜索和测试,终于在发布问题后得到了它!

您可以使用值为“0.0”的“ AnchorPane.topAnchor、AnchorPane.bottomAnchor、AnchorPane.leftAnchor、AnchorPane.rightAnchor ”fxml 命令来适应/拉伸/对齐 AnchorPane 内的子元素。因此,这些命令告诉子元素在调整大小时跟随其父元素。

我更新的代码 Main.fxml

<?xml version="1.0" encoding="UTF-8"?>

<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>

<AnchorPane fx:id="anchorPane" xmlns:fx="http://javafx.com/fxml" fx:controller="app.MainController">
    <!--<StackPane fx:id="stackPane" ></StackPane>--> <!-- replace with the following -->
    <StackPane fx:id="stackPane" AnchorPane.topAnchor="0.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" ></StackPane>
</AnchorPane>

结果如下:

在此处输入图像描述

对于 api 文档:http ://docs.oracle.com/javafx/2/api/javafx/scene/layout/AnchorPane.html

于 2013-03-05T12:59:14.633 回答
15

我在 SceneBuilder 中设计了一个 GUI,试图让主容器适应任何窗口大小。它应始终为 100% 宽。

这是您可以在 SceneBuilder 中设置这些值的地方:

SceneBuilder 中的 AnchorPane 约束

切换虚线/红线实际上只会添加/删除 Korki 在他的解决方案中发布的属性(AnchorPane.topAnchor 等)。

于 2013-11-18T13:13:08.260 回答
10

也见这里

@FXML
private void mnuUserLevel_onClick(ActionEvent event) {
    FXMLLoader loader = new FXMLLoader(getClass().getResource("DBedit.fxml"));
    loader.setController(new DBeditEntityUserlevel());

    try {
           Node n = (Node)loader.load();
           AnchorPane.setTopAnchor(n, 0.0);
           AnchorPane.setRightAnchor(n, 0.0);
           AnchorPane.setLeftAnchor(n, 0.0);
           AnchorPane.setBottomAnchor(n, 0.0);
           mainContent.getChildren().setAll(n);
    } catch (IOException e){
           System.out.println(e.getMessage());
    }
}

该场景是将子 fxml 加载到父 AnchorPane 中。为了让孩子根据其父母使用 AnChorPane.setxxxAnchor 命令进行伸展。

于 2014-03-09T01:46:35.910 回答
1

没必要让步。

只需选择窗格右键单击然后选择适合父级

它会自动调整窗格大小以锚定窗格大小。

于 2017-11-14T05:08:16.060 回答
0

这很简单,因为您使用的是FXMLBuilder

只需按照以下简单步骤操作:

  1. 在 FXMLBuilder 中打开 FXML 文件。
  2. 选择堆栈窗格。
  3. 打开布局选项卡 [FXMLBuilder 的左侧选项卡]。
  4. 设置在舞台调整大小期间要计算窗格大小的边值,如 TOP、LEFT、RIGHT、BOTTOM。
于 2014-10-14T05:20:05.300 回答
0

如果您使用的是 Scene Builder,您将在右侧看到一个手风琴面板,该面板通常具有三个选项(“属性”、“布局”和“代码”)。在第二个(“布局”)中,您将看到一个名为“[父布局] 约束”的选项(在您的情况下为“AnchorPane 约束”)。

您应该将“0”放在代表父布局的元素的四个侧面。

于 2014-12-18T08:37:32.320 回答