/*
* $Id$
*
* Copyright (c) 2000-2003 by Rodney Kinney
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License (LGPL) as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, copies are available
* at http://www.opensource.org.
*/
package VASSAL.configure;
import java.io.File;
import VASSAL.build.GameModule;
import VASSAL.tools.ArchiveWriter;
import VASSAL.tools.filechooser.FileChooser;
import VASSAL.tools.filechooser.ImageFileFilter;
/**
* A Configurer for {@link java.awt.Image} values. Allows the user to select an
* image file and writes it to a {@link ArchiveWriter}.
*/
public class ImageConfigurer extends FileConfigurer {
protected static DirectoryConfigurer resourceDirPref;
public ImageConfigurer(String key, String name, ArchiveWriter archive) {
super(key, name);
this.archive = archive;
editable = false;
}
protected FileChooser initFileChooser() {
final GameModule gm = GameModule.getGameModule();
if (resourceDirPref == null) {
resourceDirPref = new DirectoryConfigurer("imageDir", null);
gm.getPrefs().addOption(null,resourceDirPref);
}
final FileChooser fc =
FileChooser.createFileChooser(gm.getFrame(), resourceDirPref);
fc.setFileFilter(new ImageFileFilter());
return fc;
}
@Override
protected void addToArchive(File f) {
archive.addImage(f.getPath(), f.getName());
}
}