3

我在 StackPane 中调整 ImageView 的大小时遇到​​问题:如果 StackPane 是根容器并且我将图像的高度和宽度绑定到 StackPane,一切都很好。

<StackPane id="StackPane" fx:id="stack" prefHeight="400.0" prefWidth="600.0" style="-fx-background-color: lightgreen;" styleClass="mainFxmlClass" xmlns:fx="http://javafx.com/fxml" fx:controller="javafxapplication8.FXMLController">
  <children>
    <ImageView fx:id="image" fitHeight="100.0" fitWidth="300.0" pickOnBounds="true" preserveRatio="true" />
  </children>
  <stylesheets>
    <URL value="@fxml.css" />
  </stylesheets>
</StackPane>

但是,如果我将这样的堆栈窗格放在例如网格中,则图像不会正确调整大小。正如我所读到的,ImageView 的问题是不可调整大小的。有什么办法可以调整大小吗?或者你能给一些建议如何调整 ImageView 的大小吗?

4

1 回答 1

3

听起来您正在尝试为 StackPane 创建背景图像。在这种情况下,通过 CSS 应用图像可能是比 ImageView 更好的使用途径。

.stack-pane {
  -fx-background-image: url("flower.png");
  -fx-background-size: cover;
}

请参阅 JavaFX CSS 参考指南中区域规范的背景图像部分。

使ImageView 本身可调整大小是一个未解决的主要问题。该问题链接到一个简单解决方法的代码- 一个可调整大小的 ImagePane 包装一个 Image 以填充可调整大小的窗格。

于 2012-11-20T07:12:06.523 回答