面板内的JavaFX Panel自动调整大小

Kor*_*kig 45 css java pane javafx-2 fxml

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

我的面板面板应用程序

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

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

我的守则

Main.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();
  }
}
Run Code Online (Sandbox Code Playgroud)

MainController.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
   }    
}
Run Code Online (Sandbox Code Playgroud)

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>
</AnchorPane>
Run Code Online (Sandbox Code Playgroud)

style1.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%;
}
Run Code Online (Sandbox Code Playgroud)

Kor*_*kig 76

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

您可以使用值为"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>
Run Code Online (Sandbox Code Playgroud)

结果如下:

在此输入图像描述

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

  • 你能接受这个答案吗?将让我们知道这个问题有一个解决方案.好的发现,正在寻找这个. (3认同)
  • @ blo0p3r我会,但现在系统说"你可以在2天内接受你自己的答案";)希望有更多的其他建议. (2认同)

Gin*_*hen 14

我在SceneBuilder中设计了一个GUI,试图让主容器适应窗口大小.它应该总是100%宽.

您可以在SceneBuilder中设置这些值:

SceneBuilder中的AnchorPane约束

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


Dea*_*hiu 9

另见这里

@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());
    }
}
Run Code Online (Sandbox Code Playgroud)

方案是将子fxml加载到父AnchorPane中.要使孩子伸展符合其父级使用AnChorPane.setxxxAnchor命令.