【问题标题】:JavaFX | IntelliJ Idea| ImageView doesn't show image shown in SceneBuilder and it's previewJavaFX | IntelliJ 理念| ImageView 不显示在 SceneBuilder 中显示的图像,它是预览
【发布时间】:2019-01-05 13:45:49
【问题描述】:

我是 JavaFX 的新手,所以我不明白出了什么问题。我已在 SceneBuilder 中将图像添加到 ImageViews。在 SceneBuilder 和它的预览中,我们可以看到它们。但是当我运行我的应用程序时,只显示空窗口(视觉上,画布大小不同)

Main.java:

package application;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class Main extends Application {

    @Override
    public void start(Stage primaryStage) throws Exception{
        Parent root = FXMLLoader.load(getClass().getResource("MainMenu.fxml"));
        primaryStage.setTitle("MainMenu");
        primaryStage.setScene(new Scene(root));
        primaryStage.show();
    }


    public static void main(String[] args) {
        launch(args);
    }
}

MainMenu.fxml:

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

<?import java.lang.*?>
<?import javafx.scene.image.*?>
<?import javafx.scene.layout.*?>

<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="720.0" prefWidth="1280.0" xmlns="http://javafx.com/javafx/8" xmlns:fx="http://javafx.com/fxml/1" fx:controller="application.MainMenuController">
    <children>
        <ImageView fx:id="background" fitHeight="720.0" fitWidth="1280.0" pickOnBounds="true" preserveRatio="true">
         <image>
            <Image url="@../../assets/mainMenuScreen/background.png" />
         </image></ImageView>
    </children>
</AnchorPane>

在 Eclipse 中尝试过 - 它应该可以正常工作

项目结构

SceneBuilder View

Running View

附:我可以使用getClass().getClassLoader().getResource() 设置图像,但画布大小仍然比设置的大。并且路径与 SceneBuilder 中使用的路径相同

【问题讨论】:

  • 您在FXML 中设置了fitHeightfitWidth。你在代码中设置了吗?
  • SceneBuilder 使用文件系统中的相对路径来创建路径。然而,当应用程序被部署时,srcassets 的(编译的)内容被复制到类路径的根目录。 (至少大多数 IDE 是这样部署项目的。)这意味着在运行时图像的正确路径是 url="@../mainMenuScreen/background.png"
  • 不幸的是,它仍然不起作用。我收到“无法解析目录/文件”并且应用程序以空窗口运行

标签: java image javafx imageview scenebuilder


【解决方案1】:

这是因为路径。我不知道如何从 fxml 做到这一点(我试过)。 只需从代码中完成

1) 为您的 ImageView 初始化 fx:id,例如 fx:id="imView"

2) 在代码中初始化它并设置图像。 (在 src 中创建文件夹“资源”)

@FXML
private ImageView imView;

@FXML
public void initialize(){
    imView.setImage(
            new Image("resources/yourImage.jpg")
    );
}

如果您还希望图像始终适合窗口大小,则应为其添加侦听器:

想象一下你的 ImageView 在 AnchorPane 中

@FXML
private AnchorPane root;

@FXML
private ImageView imView;

@FXML
public void initialize(){
    imView.setImage(
            new Image("ims/Weissmanscore.jpg")
    );
    root.heightProperty().addListener(
            h -> imView.setFitHeight(
                    root.getHeight()
            )
    );
    root.widthProperty().addListener(
            h -> imView.setFitWidth(
                    root.getWidth()
            )
    );
}

如果您不希望您的图像不保持比例并使用窗口精确调整大小,只需在代码 imView.setPreserveRatio(false); 的 FXML preserveRatio="true" 中将 preserveRatio 设置为 false

【讨论】:

  • 感谢您的回答。它是这样工作的,我在发布之前已经尝试过了。但是窗口的大小仍然大于应有的大小。我猜,SceneBuilder 和项目本身看到了正确的路径,但不知何故,图像没有显示
猜你喜欢
  • 1970-01-01
  • 2018-03-12
  • 1970-01-01
  • 1970-01-01
  • 2023-03-13
  • 2017-07-22
  • 1970-01-01
  • 1970-01-01
  • 2016-12-13
相关资源
最近更新 更多