/**
* Copyright (C) 2002-2012 The FreeCol Team
*
* This file is part of FreeCol.
*
* FreeCol is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* FreeCol 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with FreeCol. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.freecol.common.resources;
import java.lang.reflect.Field;
import java.net.URI;
import java.util.logging.Logger;
import org.freecolandroid.repackaged.java.awt.Color;
/**
* A <code>Resource</code> wrapping a <code>Color</code>.
*
* @see Resource
* @see Color
*/
public class ColorResource extends Resource {
private static final Logger logger = Logger.getLogger(ColorResource.class.getName());
public static final String SCHEME = "color:";
private Color color;
public ColorResource(Color color) {
this.color = color;
}
/**
* Do not use directly.
* @param resourceLocator The <code>URI</code> used when loading this
* resource.
* @see ResourceFactory#createResource(URI)
*/
ColorResource(URI resourceLocator) throws Exception {
super(resourceLocator);
String colorName = resourceLocator.getSchemeSpecificPart().substring(SCHEME.length());
color = getColor(colorName);
}
/**
* Preloading is a noop for this resource type.
*/
public void preload() {}
private static boolean isHexString(String str) {
if (str == null
|| !(str.startsWith("0x") || str.startsWith("0X"))
|| str.length() <= 2) return false;
for (int i = 2; i < str.length(); i++) {
if ("0123456789ABCDEFabcdef".indexOf(str.substring(i, i+1)) < 0) {
return false;
}
}
return true;
}
/**
* Returns the <code>Color</code> identified by the given
* string. This is either a hexadecimal integer prefixed with
* "0x", or the name of a field of the Color class.
*
* @param colorName a <code>String</code> value
* @return a <code>Color</code> value
*/
public static Color getColor(String colorName) {
System.out.println("getColor name=" + colorName);
Color color = null;
if (isHexString(colorName)) {
color = new Color(colorName);
} else {
try {
Field field = Color.class.getField(colorName);
color = (Color) field.get(null);
} catch (Exception e) {
// probably a non-standard color name
logger.warning(e.toString());
}
}
if (color == null) {
System.out.println("Could not load color " + colorName + " using black as fallback");
// Fall back to black. There are places where a null colour
// can cause crashes.
color = Color.BLACK;
}
return color;
}
/**
* Gets the <code>Color</code> represented by this resource.
* @return The <code>Color</code> in it's original size.
*/
public Color getColor() {
return color;
}
}