提问者:小点点

如何将ImageView锚定到其边界窗格区域的中心?


我有一个带有ImageView的BorderPane布局,如下图所示,但ImageView始终锚定在左上角,当我调整窗口大小时,它会停留在那里。我希望ImageView将锚点保持在它绑定到的部分的中心(红色框)。这是否可以使用FXML?

FX毫升:

<?xml version="1.0" encoding="UTF-8"?>

<?import javafx.scene.control.*?>
<?import javafx.scene.Group?>
<?import javafx.scene.image.Image?>
<?import javafx.scene.image.ImageView?>
<?import javafx.scene.layout.*?>

<VBox prefWidth="800.0" prefHeight="600.0" xmlns="http://javafx.com/javafx/8.0.112" xmlns:fx="http://javafx.com/fxml/1">

    <BorderPane xmlns:fx="http://javafx.com/fxml" VBox.vgrow="ALWAYS">
        <top>
            <VBox alignment="TOP_CENTER">
                <ToolBar minHeight="50.0" prefHeight="50.0" prefWidth="800.0" stylesheets="@../css/style.css"
                         GridPane.rowIndex="1">
                    <ImageView fitHeight="35.0" fitWidth="200.0" pickOnBounds="true" preserveRatio="true">
                        <Image url="@../images/toolbar-logo.png"/>
                    </ImageView>
                </ToolBar>
                <MenuBar fx:id="menuBar" prefHeight="0.0" prefWidth="0.0"/>
            </VBox>
        </top>

        <left>
            <StackPane prefWidth="230.0" prefHeight="800.0">
                <ListView fx:id="listView"/>
            </StackPane>
        </left>

        <center>
            <StackPane>
                <ScrollPane>
                    <Group fx:id="selectionGroup">
                        <ImageView fx:id="mainImageView"/>
                    </Group>
                </ScrollPane>
            </StackPane>
        </center>

        <right>
            <TextField promptText="Text"  />
        </right>
    </BorderPane>

</VBox>

共1个答案

匿名用户

改变:

        <StackPane>
            <ScrollPane>
                <Group fx:id="selectionGroup">
                    <ImageView fx:id="mainImageView"/>
                </Group>
            </ScrollPane>
        </StackPane>

收件人:

        <StackPane>
            <children>
                <ImageView fx:id="mainImageView" fitHeight="150.0" fitWidth="200.0" pickOnBounds="true" preserveRatio="true" />                    
            </children>
        </StackPane>

您可能需要调整fitWidthfitHeight属性。