与父级扩展的JavaFX布局

时间:2013-10-04 06:46:46

标签: java layout user-interface javafx

我在项目中使用JavaFX而不是Swing,因为增强的多媒体,webviewer和使用视觉效果的可能性。但是,我从网络上发现的内容(http://docs.oracle.com/javafx/2/layout/jfxpub-layout.htm和其他人)中了解到, JavaFX 布局管理器专注于根据大小调整父级的大小内容,而 Swing 专注于根据父缩放内容,至少基于正在使用的Layout

现在我正在使用Accordion和一些TitledPane个孩子。其中一个包含GridPane,原因很简单,这是我知道模仿GridLayout的最佳方式(正如我在上一个问题中所学到的那样:JavaFX layout equivalent to GridLayout)。我想将TitledPane的内容拆分为2行1列,每行的TitledPane可用空间高度为50%(使用Stage缩放{ {1}}),相当于SceneGridLayout(2,1)所能完成的内容。为此,我使用BorderLayout.CENTER添加了GridPaneRowConstraintsetPercentHeight(50)添加了ColumnConstraintsetPercentWidth(100)。但是,我注意到内容正在适当地缩放网格,但网格没有占用TitledPane中的所有可用空间(因为它显然不像BorderPane的中心)。我还尝试使用setMaxWidth来与父级进行内容扩展,但它似乎也不起作用(如此处所述:JavaFX: How to make my custom component use all available space from parent layout?)。即使这样,我是否需要在我的UI元素树中将最大宽度设置为EACH后代,以使它们全部缩放?

无论哪种方式,有没有人知道如何制作一个TitledPane,其中有两个相等的空格,在另一个下方,与标题窗格的大小成比例?

column width does not take up all available space

1 个答案:

答案 0 :(得分:10)

事实上,你的gridpane正在增长以填补其所有父母。 考虑下面的代码,我已经将一个背景颜色(红色)添加到gridpane以进行调试。

Accordion accordion = new Accordion();
TitledPane titledPane = new TitledPane();
titledPane.setText("Title");
GridPane gridPane = new GridPane();
gridPane.setStyle("-fx-background-color:red");

gridPane.add(new TextArea("Hello"), 0, 0);
gridPane.add(new TextArea("World"), 0, 1);

titledPane.setContent(gridPane);
accordion.getPanes().add(titledPane);

如果执行此代码,则gridpane将填充其所有父代(检查红色跨越titledpane内容)。

但是,gridpane的内容不会填满所有列。如果您尝试调整窗口大小,您将看到textareas的宽度与gridpane一起没有变化。 要解决这个问题,您需要告诉gridpane的第一列与gridpane本身一起增长。 这样做的方法是添加以下约束:

ColumnConstraints columnConstraints = new ColumnConstraints();
columnConstraints.setFillWidth(true);
columnConstraints.setHgrow(Priority.ALWAYS);
gridPane.getColumnConstraints().add(columnConstraints);