Swing/ClassLoader のバックアップの現在との差分(No.13)
TITLE:ClassLoaderでリソース(URL)を取得
Posted by aterai at 2006-05-22
ClassLoaderでリソース(URL)を取得
クラスパスからのエントリ(相対パス風)を使って、ClassLoaderからURLを取得します。- category: swing folder: ClassLoader title: ClassLoaderでリソース(URL)を取得 tags: [ClassLoader, Resource, URL] author: aterai pubdate: 2006-05-22T09:59:23+09:00 description: クラスパスからのエントリ(相対パス風)を使って、ClassLoaderからURLを取得します。 image:
概要
クラスパスからのエントリ(相対パス風)を使って、ClassLoader
からURL
を取得します。
- &jnlp;
- &jar;
- &zip;
Screenshot
Advertisement
サンプルコード
#spanend
#spanadd
* サンプルコード [#sourcecode]
#spanend
#spanadd
#code(link){{
#spanend
URL url = getClass().getClassLoader().getResource("example/test.png");
#spandel
//URL url = getClass().getResource("test.png");
#spanend
#spanadd
// URL url = Thread.currentThread().getContextClassLoader().getResource("example/test.png");
#spanend
#spanadd
// URL url = getClass().getResource("test.png");
#spanend
JLabel icon = new JLabel(new ImageIcon(url));
JLabel path = new JLabel(url.toString());
解説
ClassLoaderを使用して、位置に依存しない方法でリソース(URL)を取得します。解説
ClassLoader
を使用して、位置に依存しない方法でリソース(URL
)を取得します。
以下、".\target\classes\example\test.png"にある画像ファイルのURLをクラスパスからのエントリ(相対パス風)を使って取得する場合を考えます。
- 例えば
new ImageIcon(String filename)
のようにファイルパスを文字列で指定した場合、このファイルパスが位置(カレントディレクトリ)に依存しているため、実行時に別のディレクトリから起動したり、jar
ファイルにまとめたりするとファイルが参照できなくなる
.\target\classes\example\test.png
にある画像ファイルのURL
をクラスパスからのエントリ(相対パス風)を使って取得する場合を考えます。
上記のサンプルに添付しているバッチファイルでは、クラスパスは次のように設定しています。
java -classpath ".\target\classes" example.MainPanelClassLoader#getResourceメソッドを使用する場合は、以下のようにクラスパスからのエントリを使用します。このエントリは、相対パス風で頭に/は付けず、/区切りで記述します。
ClassLoader#getResource
メソッドを使用する場合は、以下のようにクラスパスからのエントリを使用します。このエントリは、相対パス風で頭に/
は付けず、/
区切りで記述します。
getClass().getClassLoader().getResource("example/test.png");
#spandel
//ただし、getClass().getClassLoader().getResource("./example/test.png");
#spanend
#spandel
//だとjar内にパッケージした時うまくいかない。
#spanend
#spanadd
// ただし、getClass().getClassLoader().getResource("./example/test.png");
#spanend
#spanadd
// だとjar内にパッケージした場合で失敗する
#spanend
ClassLoaderからでは無く、Class#getResourceメソッドを使う方法もあります。この場合、エントリ名がメソッド内で以下のように変換されます。
- 相対パス風(頭に/が付かない)の場合
- "." が "/" に変換された、modified_package_nameが名前の前に補完される
- 例えば、com.example.Testクラスなら、"com/example/"
- このサンプルではexample.MainPanelクラスなので、"example/"が補完されて、"example/test.png"になる
ClassLoader
からでは無く、Class#getResource
メソッドを使う方法もあります。この場合、エントリ名がメソッド内で以下のように変換されます。
- 相対パス風(頭に
/
が付かない)の場合-
.
が/
に変換された、modified_package_name
が名前の前に補完される - 例えば、
com.example.Test
クラスなら、com/example/
- このサンプルでは
example.MainPanel
クラスなので、example/
が補完されて、example/test.png
になる
-
#spandel
getClass().getResource("test.png");
#spanend
#spandel
//getClass().getClassLoader().getResource("example/test.png");と同じ
#spanend
#spanadd
getClass().getResource("test.png"); //or MainPanel.class.getResource("test.png");
#spanend
#spanadd
// getClass().getClassLoader().getResource("example/test.png");と同じ
#spanend
- 絶対パス風(頭に/が付く)の場合
- modified_package_nameは補完せず、頭の "/" は削除される
- 絶対パス風(頭に
/
が付く)の場合-
modified_package_name
は補完せず、頭の/
は削除される
-
getClass().getResource("/test.png");
#spandel
//getClass().getClassLoader().getResource("test.png");と同じ
#spanend
#spandel
//上記の相対パスと同じリソースを取得する場合は、
#spanend
#spandel
//getClass().getResource("/example/test.png");としなくてはならない
#spanend
#spanadd
// getClass().getClassLoader().getResource("test.png");と同じ
#spanend
#spanadd
// 上記の相対パスと同じリソースを取得する場合は、
#spanend
#spanadd
// getClass().getResource("/example/test.png");としなくてはならない
#spanend
クラスパス上にs同名のリソースが複数存在する場合は、最初に見つかったものが使用されます。
- src.zipをダウンロードして適当な場所に展開する
- c:\temp\example\test.png という画像ファイルを別途用意する
- 1.で展開したフォルダにあるrun.batの6行目(クラスパス)を以下のように変更
set LOCALCLASSPATH=c:\temp;.\target\classes
- ant でコンパイルして、修正したrun.batで実行 クラスパス上に同名のリソースが複数存在する場合は、最初に見つかったものが使用されます。
-
src.zip
をダウンロードして適当な場所に展開する -
c:\temp\example\test.png
という画像ファイルを別途用意する - 展開したフォルダにある
run.bat
のクラスパスを以下のように変更(c:\temp
を最初に追加)
参考リンク
- 位置に依存しない方法でのリソースへのアクセス
- Loading Images Using getResource
#spanend #spanadd set MAIN_CLASS=example.MainPanel #spanend #spanadd rem set CLASSPATH=.\target\classes #spanend #spanadd set CLASSPATH=c:\temp;.\target\classes #spanend #spanadd
コメント
- 「クラスパスからのパス」などの意味が分かり辛いので、JarURLConnection (Java Platform SE 6)を参考にして「パス」を「エントリ」に変更してみました。 -- aterai
-
ant
などでコンパイルして、修正したrun.bat
で実行
src.zip
に元々入っていた適当な場所/test.png
ではなく、file:/C:/temp/example/test.png
というURL
がgetResource
で取得できます。