如何将图像文件加载到ImageView?

问题描述 投票:6回答:3

我试图从文件选择器中选择图像文件后立即显示它。文件选择器仅限于.png和.jpg文件,所选文件存储在File类型的变量中。为此,我已经设置了ImageView,并且我希望使用此新文件设置图像,唯一的问题是它的类型是File not Image。

如何实现?到目前为止的代码...

    public void fileSelection(){

        FileChooser fileChooser = new FileChooser();
        fileChooser.setTitle("Select Profile Picture");
        fileChooser.getExtensionFilters().addAll(new FileChooser.ExtensionFilter("Image Files", "*.png", "*jpg"));
        File selectedFile = fileChooser.showOpenDialog(null);
        File selectedFileInput = selectedFile;

        if(selectedFile != null) {
            selectedFileOutput.setText("File selected: " + selectedFile.getName());
            previewPicture.setImage();
        } else {
            selectedFileOutput.setText("Please select a profile picture...");
        }
    }
java image javafx imageview filechooser
3个回答
8
投票

您可以简单地通过以下方式创建图像

Image image = new Image(selectedFile.toURI().toString());

然后将其放入ImageView

previewPicture.setImage(image);

[其他构造函数提供了对加载图像所需资源的更多控制。如果要强制将图像设置为特定大小,则可以在加载时调整其大小,如果用户选择较大的图像,而只想显示缩小的版本,则可以节省内存。此外,加载大图像可能会花费一些时间,因此您不应将其加载到UI线程上。采用字符串形式的URL的Image构造函数具有自动在后台线程中加载图像的选项。下面的命令强制宽度和高度均不超过240像素(同时保持原始宽高比),并在背景中加载图像(因此不会阻塞UI):

Image image = new Image(selectedFile.toURI().toString(),
    240, // requested width
    240, // requested height
    true, // preserve ratio
    true, // smooth rescaling
    true // load in background
);

请参阅documentation以获取其他可用的构造函数。


2
投票

您创建图像并如下设置为ImageView

  Image image = new Image(new FileInputStream(selectedFile));
  previewPicture.setImage(image);

0
投票

我添加一个较晚的答案来演示不同的图像文件加载替代方法:

import java.io.File;
import java.net.URL;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.image.Image;
import javafx.scene.image.ImageView;
import javafx.scene.layout.Pane;
import javafx.scene.layout.TilePane;
import javafx.stage.Stage;

public class ImagesFromFile extends Application {

    @Override
    public void start(Stage primaryStage) throws Exception{
        primaryStage.setTitle("Load Images From File");
        primaryStage.setScene(new Scene(new ImagePanel().getPane()));
        primaryStage.show();
    }

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

/**
<pre>
Folders structure:

   -Project
    | - src
    |   | - package
    |   |       | - ImagePanel.java
    |   |       | - red_dot.png
    |   |
    |   | - resources
    |           | - blue_dot.png
    |
    | - black_dot.png
 </pre>
*/

class ImagePanel{

    private Pane pane;

    ImagePanel() {

        try{

            //not embedded resource. doesn't work when packaged in jar
            File file = new File("black_dot.png");
            Image imageFromProjectFolder = new Image(file.toURI().toString());//or new Image(new FileInputStream("black_dot.png"));
            ImageView view1 = new ImageView(imageFromProjectFolder);

            URL url = getClass().getResource("red_dot.png");
            Image imageFromSourceFolder =  new Image(url.openStream());
            ImageView view2 = new ImageView(imageFromSourceFolder); //or new ImageView("/package/red_dot.png");

            url = getClass().getResource("/resources/blue_dot.png");
            Image imageFromReourceFolder = new Image(url.openStream());
            ImageView view3 = new ImageView(imageFromReourceFolder); //or new ImageView("/resources/blue_dot.png");

            pane = new TilePane(view1, view2, view3);

        } catch (Exception ex) {ex.printStackTrace();}
    }

    Pane getPane(){
        return pane;
    }
} 
© www.soinside.com 2019 - 2024. All rights reserved.