Where does javafx.scene.image.Image(“flower.png”)

2020-01-24 13:25发布

I would like to know what the JavaFX Image constructor's relative path resolution algorithm is for:

  1. Stand-alone apps.
  2. Browser deployed apps.
  3. Webstart deployed apps.

If the algorithm may look in multiple locations, I'd like to know what they are for each of the above deployment scenarios.

If the behaviour for stand-alone apps is different when the app is placed in a jar, I'd like to know that too.

3条回答
霸刀☆藐视天下
2楼-- · 2020-01-24 13:51

The answer is "/" if case you are using getClass().getResourceAsStream(), i.e. the root of your jar file (inside it). Not user.dir nor where the package is hosted

查看更多
对你真心纯属浪费
3楼-- · 2020-01-24 14:00
  1. search directory where class files( name of class getClass().getName().toString() ) related to your .java file are present, copy and paste your image there
  2. Image image=new Image(getClass().getResourceAsStream("yourImageName.jpg")); is must.

In NetBeans the directory where classes are present NetBeansProjects/JavaFXProjectName/build/classes/packageName/

查看更多
▲ chillily
4楼-- · 2020-01-24 14:14

Then user provides relative path to new Image(String url) it will be relative against workdir of the app aka System.getProperty("user.dir")

  1. For stand-alone app it's a folder you started an application from
  2. For web-start app being run from command line (javaws myfxapp.jnlp) it works the same way as with standalone app
  3. For plugin start or webstart app loaded from browser you can't reliably be sure about workdir location. It depends on browser and even on installed plugins for that browser.

So general direction is: for standalone apps use url same way as you'll use it in new File(String url). For jnlp/plugin use full url with protocol or Class.getResource() approach.

Update: Please, note, this behavior is going to be clarified and changed in 2.2. See http://javafx-jira.kenai.com/browse/RT-18291

The following comment is from RT-18291 and outlines the intended changes for 2.2:

Martin Sladecek added a comment - May, 15 2012 10:53 AM After discussion with Richard Bair, we decided to change the current (undocumented) behavior for paths. Currently, they are treated as user.dir relative. All path, with or without leading slash will be now resolved as relative to classpath, which will be consistent with CSS and more corresponds to what might users expect. For user.dir relative paths, "file:" URL can be still used.

查看更多
登录 后发表回答