我是JavaFX的新手,在我的sample.fxml文件中找到了两个ColumnConstraints,但是我不知道为什么有两个,因为当我删除其中一个时,视图改变了。

<GridPane fx:controller="sample.Controller" xmlns:fx="http://javafx.com/fxml"
          alignment="center" hgap="10" vgap="10" gridLinesVisible="true">

    <columnConstraints>

        <ColumnConstraints percentWidth="100"/>
        <ColumnConstraints percentWidth="100"/>

    </columnConstraints>


</GridPane>

最佳答案

GridPane具有一或多个列。每列都可以施加约束,这可以通过添加到ColumnConstraints列表中的GridPane#getColumnConstraints()实例来实现。从文档中:


  返回列约束的列表。可以添加列约束以显式控制各个列的大小和布局行为。如果未设置,则根据内容计算列的大小和布局行为。 ObservableList中的索引表示列号,因此第一列的列约束位于0(加重)位置。


注意:如果您不知道,FXML文件仅描述对象图,然后FXMLLoader解析该文件并设置适当的属性或向适当的集合添加元素。 <columnConstraints>元素引用上面提到的列表,并且ColumnConstraints实例被添加到该列表中。有关更多信息,请参见Introduction to FXML

如您所见,列表中ColumnConstraints的索引确定约束适用于哪一列。您的FXML文件添加了两个约束,这意味着您将同时为第一列和第二列添加约束。不过,公平地说,两列都占用100%的宽度是没有意义的。现在,如果您的sample.fxml文件是在发布时创建的(即,您所做的更改不多),您想知道为什么您的工具会自动添加两个约束,我无法回答。

注意,没有要求每个索引都需要唯一的ColumnConstraints实例。换句话说,可以通过将同一实例多次添加到列表中来将同一实例用于多个列。在FXML中,如下所示:

<GridPane fx:controller="sample.Controller" xmlns:fx="http://javafx.com/fxml"
          alignment="center" hgap="10" vgap="10" gridLinesVisible="true">

    <fx:define>
        <ColumnConstraints fx:id="colConstraints" percentWidth="100"/>
    </fx:define>

    <columnConstraints>

        <fx:reference source="colConstraints"/>
        <fx:reference source="colConstraints"/>

    </columnConstraints>


</GridPane>


至于为什么在删除ColumnConstraints之一时视图发生变化的原因,即使该列中没有内容,约束的存在也会迫使该列存在。当列中没有内容时,如果删除约束,则该列将不复存在。

RowConstraints的行为相同,只是约束适用于行而不是列(显然)。

09-16 05:22