package org.richfaces.component;
import java.awt.Color;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.jboss.arquillian.core.spi.Validate;
/**
* Provides Color manipulations and functionality.
*
* @author <a href="mailto:lfryc@redhat.com">Lukas Fryc</a>
* @version $Revision$
*/
public final class ColorUtils {
private static final int HEX_RADIX = 16;
private static final int RGB_PARTS = 3;
private static final short RED_COMPONENT = 0;
private static final short GREEN_COMPONENT = 1;
private static final short BLUE_COMPONENT = 2;
private ColorUtils() {
}
/**
* <p>
* Converts a string representation of color to integer.
* </p>
*
* <p>
* Works with two formats:
* </p>
*
* <ul>
* <li><code>#09FE4A</code> - <b>hexadecimal</b></li>
* <li><code>rgb(132, 5, 18)</code> - <b>decimal</b></li>
* </ul>
*
* @param colorValue string represented in one of two formats
* @return integer value of color derived from string representation
*/
public static int convertToInteger(String colorValue) {
Validate.notNull(colorValue, "colorValue should not be null");
int result = 0;
if (colorValue.charAt(0) == '#') {
result = Integer.parseInt(colorValue.substring(1), HEX_RADIX);
} else {
Matcher matcher = Pattern.compile("(\\d+)").matcher(colorValue);
int[] array = new int[RGB_PARTS];
for (int i = 0; i < RGB_PARTS; i++) {
if (!matcher.find()) {
throw new IllegalArgumentException(colorValue);
}
array[i] = Short.parseShort(matcher.group(1));
}
result = new Color(array[RED_COMPONENT], array[GREEN_COMPONENT], array[BLUE_COMPONENT]).getRGB();
}
return result;
}
/**
* <p>
* Converts a string representation of color to AWT Color object.
* </p>
*
* <p>
* Works with two formats:
* </p>
*
* <ul>
* <li><code>#09FE4A</code> - <b>hexadecimal</b></li>
* <li><code>rgb(132, 5, 18)</code> - <b>decimal</b></li>
* </ul>
*
* @param colorValue string represented in one of two formats
* @return AWT's Color value representation of string-represented colorValue; if colorValue is null, returns null
*/
public static Color convertToAWTColor(String colorValue) {
if (colorValue == null) {
return null;
}
int convertedValue = convertToInteger(colorValue);
return new Color(convertedValue);
}
}