Provavelmente uma pergunta muito simples, mas eu não tenho sido capaz de descobrir isso.
I têm um ScrollPane (feito de etiqueta.) Dentro de um VBox, dentro de um SplitPane:
(Arquivo fxml completa na parte inferior)
Quando você expande a janela ou o seperator painel dividido horizontalmente, o Vbox estende automaticamente para caber, o rótulo re-centers appropriatelly, e painel de rolagem se expande para ajustar o vbox. Isso não acontece quando epxanding verticalmente, e eu gostaria que ele. Como posso conseguir isso? Se houver um recipiente diferente eu deveria estar usando em vez disso, por favor diga.
Gif dos meus problemas se isso ajuda: arquivo fxml completa:
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.text.*?>
<AnchorPane prefHeight="600.0" prefWidth="800.0" xmlns="http://javafx.com/javafx/10.0.2-internal" xmlns:fx="http://javafx.com/fxml/1" fx:controller="main.java.ui.DefaultLayoutController">
<children>
<BorderPane prefHeight="600.0" prefWidth="800.0" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
<top>
<MenuBar BorderPane.alignment="CENTER">
<menus>
<Menu mnemonicParsing="false" text="File">
<items>
<MenuItem mnemonicParsing="false" text="Close" />
</items>
</Menu>
<Menu mnemonicParsing="false" text="Edit">
<items>
<MenuItem mnemonicParsing="false" text="Delete" />
</items>
</Menu>
<Menu mnemonicParsing="false" text="Help">
<items>
<MenuItem mnemonicParsing="false" text="About" />
</items>
</Menu>
</menus>
</MenuBar>
</top>
<center>
<SplitPane dividerPositions="0.5" prefHeight="160.0" prefWidth="200.0" BorderPane.alignment="CENTER">
<items>
<AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="160.0" prefWidth="100.0">
<children>
<VBox prefHeight="573.0" prefWidth="306.0" style="-fx-background-color: #ccbfb1;" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
<children>
<Label alignment="CENTER" maxWidth="Infinity" prefHeight="61.0" prefWidth="260.0" style="-fx-alignment: center; -fx-background-color: #e6d7c8;" text="Text" textAlignment="CENTER">
<font>
<Font name="AdobeDevanagari-Regular" size="51.0" />
</font>
</Label>
<ScrollPane fx:id="mainScrollPane" prefHeight="559.0" prefWidth="453.0">
<content>
<AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="200.0" prefWidth="200.0" />
</content>
</ScrollPane>
</children>
</VBox>
</children>
</AnchorPane>
<AnchorPane minHeight="0.0" minWidth="0.0" prefHeight="573.0" prefWidth="364.0">
<children>
<VBox prefHeight="573.0" prefWidth="396.0" style="-fx-background-color: #e6c896;" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0" />
</children>
</AnchorPane>
</items>
</SplitPane>
</center></BorderPane>
</children>
</AnchorPane>
Uma maneira que você pode conseguir isso é através da criação da altura máxima do VBox
e seus elementos para Double.MAX_VALUE
usando o setMaxHeight(double)
método. Alternativamente, você pode usar o estático VBox.setVgrow(Priority)
método (recomendado, tanto quanto eu estou ciente) sobre todos os VBox
filhos de s. Você pode iterar sobre as crianças usando apenas um regular for
loop:
for(Node child : yourBox.getChildren()) {
VBox.setVgrow(child, Priority.ALWAYS);
}