我只是尝试使用JavaFX并且正在强行进入它,因为它被认为是未来。我正在尝试创建一个包含4列的表。列和表应调整大小以填充父窗格。我不能为我的生活让这个工作。我现在已经尝试了4个多小时,桌面视图没有调整大小。
这是我的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.*?>
<?import java.net.*?>
<?import javafx.geometry.*?>
<?import javafx.geometry.Insets?>
<?import javafx.scene.control.*?>
<?import javafx.scene.control.cell.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.text.*?>
<?import javafx.collections.*?>
<?import t.cubed.fxml.*?>
<BorderPane styleClass="root" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/8" fx:controller="t.cubed.fxml.FXMLDocumentController">
<top>
<MenuBar fx:id="menuBar" styleClass="menu-bar">
<menus>
<Menu text="File">
<items>
<MenuItem onAction="#handleOpenAction" text="Open" />
<MenuItem onAction="#handleExitAction" text="Exit" />
</items>
</Menu>
<Menu text="Edit">
<items>
<MenuItem onAction="#handleWeightAction" text="Edit Weights" />
<MenuItem onAction="#handleFilterAction" text="Edit Filters" />
<MenuItem onAction="#handleOptionsAction" text="Options" />
</items>
</Menu>
</menus>
</MenuBar>
</top>
<center>
<GridPane>
<!--
<padding>
<Insets bottom="10.0" left="10.0" right="10.0" top="10.0"/>
</padding>
-->
<TableView fx:id="testTable" GridPane.columnIndex="0" GridPane.rowIndex="0" GridPane.columnSpan="1">
<columnResizePolicy>
<TableView fx:constant="CONSTRAINED_RESIZE_POLICY" />
</columnResizePolicy>
<columns>
<TableColumn text="TEST NUMBER">
<cellValueFactory>
<PropertyValueFactory property="testNumber" />
</cellValueFactory>
</TableColumn>
<TableColumn text="TEST NAME">
<cellValueFactory>
<PropertyValueFactory property="testName" />
</cellValueFactory>
</TableColumn>
<TableColumn text="TEST TIME(ms)">
<cellValueFactory>
<PropertyValueFactory property="testTime" />
</cellValueFactory>
</TableColumn>
<TableColumn text="BEST MATCH">
<cellValueFactory>
<PropertyValueFactory property="bestMatch" />
</cellValueFactory>
</TableColumn>
</columns>
<items>
<!--
<FXCollections fx:factory="observableArrayList">
<TestTableModel testNumber="100" testName="Test1234" testTime="0.34" bestMatch="99"/>
</FXCollections>
-->
</items>
</TableView>
</GridPane>
</center>
<stylesheets>
<URL value="@t-cubed.css" />
</stylesheets>
</BorderPane>
答案 0 :(得分:21)
可调整大小的布局如何工作
JavaFX中可调整大小的项目的大小由放置项目的布局管理器管理。
您需要做什么
对于您的特定问题,您需要设置GridPane大小调整约束来管理放置在网格中的TableView。
请参阅我在TableView上添加的GridPane.hgrow
和GridPane.vgrow
约束:
<TableView fx:id="testTable"
GridPane.columnIndex="0"
GridPane.columnSpan="1"
GridPane.hgrow="ALWAYS"
GridPane.vgrow="ALWAYS"
GridPane.rowIndex="0">
FXML只反映了Java API,所以你也可以在Java源代码中做同样的事情。即GridPane.setHGrow(node, priority)
。但是,如果您使用FXML进行布局,建议在FXML中定义布局约束。
重构样本
我在Scene Builder 2中加载了你的FXML并设置了相应的约束,当我使用Scene Builder的预览功能时,它似乎会自动调整大小。
<?xml version="1.0" encoding="UTF-8"?>
<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import java.net.*?>
<?import javafx.geometry.*?>
<?import javafx.geometry.Insets?>
<?import javafx.scene.control.*?>
<?import javafx.scene.control.cell.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.text.*?>
<?import javafx.collections.*?>
<?import t.cubed.fxml.*?>
<BorderPane styleClass="root" xmlns="http://javafx.com/javafx/8" xmlns:fx="http://javafx.com/fxml/1" fx:controller="t.cubed.fxml.FXMLDocumentController">
<top>
<MenuBar fx:id="menuBar" styleClass="menu-bar">
<menus>
<Menu text="File">
<items>
<MenuItem onAction="#handleOpenAction" text="Open" />
<MenuItem onAction="#handleExitAction" text="Exit" />
</items>
</Menu>
<Menu text="Edit">
<items>
<MenuItem onAction="#handleWeightAction" text="Edit Weights" />
<MenuItem onAction="#handleFilterAction" text="Edit Filters" />
<MenuItem onAction="#handleOptionsAction" text="Options" />
</items>
</Menu>
</menus>
</MenuBar>
</top>
<center>
<GridPane>
<children>
<!--
<padding>
<Insets bottom="10.0" left="10.0" right="10.0" top="10.0"/>
</padding>
-->
<TableView fx:id="testTable" GridPane.columnIndex="0" GridPane.columnSpan="1" GridPane.hgrow="ALWAYS" GridPane.rowIndex="0" GridPane.vgrow="ALWAYS">
<columnResizePolicy>
<TableView fx:constant="CONSTRAINED_RESIZE_POLICY" />
</columnResizePolicy>
<columns>
<TableColumn text="TEST NUMBER">
<cellValueFactory>
<PropertyValueFactory property="testNumber" />
</cellValueFactory>
</TableColumn>
<TableColumn text="TEST NAME">
<cellValueFactory>
<PropertyValueFactory property="testName" />
</cellValueFactory>
</TableColumn>
<TableColumn text="TEST TIME(ms)">
<cellValueFactory>
<PropertyValueFactory property="testTime" />
</cellValueFactory>
</TableColumn>
<TableColumn text="BEST MATCH">
<cellValueFactory>
<PropertyValueFactory property="bestMatch" />
</cellValueFactory>
</TableColumn>
</columns>
<items>
<!--
<FXCollections fx:factory="observableArrayList">
<TestTableModel testNumber="100" testName="Test1234" testTime="0.34" bestMatch="99"/>
</FXCollections>
-->
</items>
</TableView>
</children>
<columnConstraints>
<ColumnConstraints />
</columnConstraints>
<rowConstraints>
<RowConstraints />
</rowConstraints>
</GridPane>
</center>
<stylesheets>
<URL value="@t-cubed.css" />
</stylesheets>
</BorderPane>
一些建议
您将TableView放在GridPane中。在你的情况下使用GridPane有点奇怪,因为GridPane只在GridPane中放置一个节点。只需将TableView直接放在BorderPane的中心或使用更简单的布局父级(如StackPane)就可以正常工作。但也许这只是一个更复杂的UI的缩减版本,所以也许这就是你使用GridPane的原因。
进一步阅读
如果您有时间,请在Node,Pane,Group和GridPane javadoc中阅读JavaFX中的布局,并尝试此layout bounds demo
其他评论问题
提到StackPane会起作用,但StackPanes似乎没有Hgrow和Vgrow?
StackPanes不需要Hgrow或Vgrow约束。这些约束设置Priorities,定义为:
枚举用于确定给定的增长(或收缩)优先级 当节点的区域有更多(或更少)可用空间时,节点的布局区域 并且多个节点正在争夺该空间。
使用StackPane,所有孩子都是相互叠加的,他们不会争夺空间,因此子节点的增长优先级设置不适用。
答案 1 :(得分:0)
完成一些功课后,我们想出了一些有关FXML容器的资格信息。由@ user3403469给出的相同原因。在Scene Builder中,有一长串 容器&#39;。 Imho,只有这9个元素和Pane符合布局容器,因为它们继承自
&LT; Pane&GT; ......所有Pane classes的父母。虽然Pane和Control都继承自Region,但Pane子类具有布局属性。
* <AnchorPane>
* <BorderPane>
* <FlowPane>
* <GridPane>
* <StackPane>
* <TextFlow>
* <TilePane>
* <HBox>
* <VBox>
您可以认为Control子类或多或少地继承了事件和操作。类似于布局的布局需要来自封装区域,并且唯一可以使用布局元素来封装“控制”区域。是一个&#39; Pane&#39;。
这些FXML元素将成为定制的布局管理者&#39;在@ jewelsea的回答和其他地方描述。
我想&#39;控制&#39;容器仍然是FXML中的容器。看来他们需要在内心里面。一个做好事的小组; - )
更正和评论欢迎 。
相关: