私はそれは非常に単純なことだと思うが、私はそれの後ろに取得することはできません。私が欲しいのは、fxmlにリンクされたImageViewの上に画像を表示することです。ここに私のコードがあります:
package application;
import Java.io.File;
import javafx.application.Application;
import javafx.stage.Stage;
import javafx.scene.Scene;
import javafx.scene.image.Image;
import javafx.scene.image.ImageView;
import javafx.scene.layout.AnchorPane;
import javafx.fxml.FXML;
import javafx.fxml.FXMLLoader;
public class Main extends Application
{
@FXML
private ImageView imageView;
@Override
public void start(Stage primaryStage)
{
try
{
AnchorPane root = (AnchorPane)FXMLLoader.load(getClass().getResource("Sample.fxml"));
Scene scene = new Scene(root,400,400);
scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
primaryStage.setTitle("Hello World");
File file = new File("src/Box13.jpg");
Image image = new Image(file.toURI().toString());
imageView = new ImageView(image);
//root.getChildren().add(imageView);
primaryStage.setScene(scene);
primaryStage.show();
} catch(Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
launch(args);
}
}
そして、私のfxmlファイル
<?xml version="1.0" encoding="UTF-8"?>
<?import Java.lang.*?>
<?import javafx.scene.image.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.layout.AnchorPane?>
<AnchorPane prefHeight="316.0" prefWidth="321.0" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/2.2" fx:controller="application.SampleController">
<children>
<ImageView fx:id="imageView" fitHeight="150.0" fitWidth="200.0" layoutX="61.0" layoutY="83.0" pickOnBounds="true" preserveRatio="true" >
</ImageView>
</children>
</AnchorPane>
コメントアウトされた行を含めると正常に機能するため、ファイルのリンクに問題はないはずです。これはJavaのみで行われますが、他のすべてのコンポーネントにfxmlを使用しているため、ここではfxmlを使用しますが、ImageViewでは機能せず、また、新しいコントローラークラスを作成してImageViewをリンクしようとしましたが、どちらも機能しません。
ありがとう
FXMLを使用する場合は、コントローラーを分離する必要があります(SampleControllerで行っていたように)。次に、fx:controller
は、FXMLでそれを指す必要があります。
おそらく、initialize
インターフェイスの一部である、コントローラーにInitializable
メソッドがありません。このメソッドはFXMLがロードされた後に呼び出されるため、画像をそこに設定することをお勧めします。
SampleController
クラスは次のようなものでなければなりません:
public class SampleController implements Initializable {
@FXML
private ImageView imageView;
@Override
public void initialize(URL location, ResourceBundle resources) {
File file = new File("src/Box13.jpg");
Image image = new Image(file.toURI().toString());
imageView.setImage(image);
}
}
ここでテストしたところ、動作しています。
毎回異なるイメージを動的にロードする場合を除き、初期化子は必要ありません。 fxmlでできるだけ多くのことを行うことは、より組織化されていると思います。必要なことを行うfxmlファイルを次に示します。
<?xml version="1.0" encoding="UTF-8"?>
<?import Java.lang.*?>
<?import javafx.scene.image.*?>
<?import javafx.scene.layout.*?>
<AnchorPane
xmlns:fx="http://javafx.co/fxml/1"
xmlns="http://javafx.com/javafx/2.2"
fx:controller="application.SampleController"
prefHeight="316.0"
prefWidth="321.0"
>
<children>
<ImageView
fx:id="imageView"
fitHeight="150.0"
fitWidth="200.0"
layoutX="61.0"
layoutY="83.0"
pickOnBounds="true"
preserveRatio="true"
>
<image>
<Image
url="src/Box13.jpg"
backgroundLoading="true"
/>
</image>
</ImageView>
</children>
</AnchorPane>
ImageタグのbackgroundLoadingプロパティの指定はオプションで、デフォルトはfalseです。画像をロードするのに少し時間がかかる場合、backgroundLoadingをtrueに設定することをお勧めします。これにより、画像がロードされるまでプレースホルダーが使用され、プログラムはロード中にフリーズしません。
@FXML
ImageView image;
@Override
public void initialize(URL url, ResourceBundle rb) {
image.setImage(new Image ("/about.jpg"));
}
src/sample/images/shopp.png
**
Parent root =new StackPane();
ImageView ımageView=new ImageView(new Image(getClass().getResourceAsStream("images/shopp.png")));
((StackPane) root).getChildren().add(ımageView);
**
次のように使用するよりも、画像をリソースに配置することをお勧めします。
imageView = new ImageView("/gui.img/img.jpg");
JavaFXを使用して画像をロードするには、以下の例をご覧ください。
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.image.Image;
import javafx.scene.image.ImageView;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
public class LoadImage extends Application {
public static void main(String[] args) {
Application.launch(args);
}
@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("Load Image");
StackPane sp = new StackPane();
Image img = new Image("javafx.jpg");
ImageView imgView = new ImageView(img);
sp.getChildren().add(imgView);
//Adding HBox to the scene
Scene scene = new Scene(sp);
primaryStage.setScene(scene);
primaryStage.show();
}
}
プロジェクトにImageという名前のソースフォルダーを1つ作成し、そのフォルダーに画像を追加します。そうしないと、次のように外部URLから画像を直接読み込むことができます。
Image img = new Image( " http://mikecann.co.uk/wp-content/uploads/2009/12/javafx_logo_color_1.jpg ");