在以项目中遇到需要把HTML中“#FFFFFF”格式的颜色,转化成jxl.format.Colour,方便把字体的颜色导出到Excel中。
从“#FFFFFF” 到java.awt.Color,使用 Color color = Color.decode(cStr);
从java.awt.Color 到 jxl.format.Colour 代码如下:
protected static Colour getNearestColour(Color awtColor) {
Colour color = null;
Colour[] colors = Colour.getAllColours();
if ((colors != null) && (colors.length > 0)) {
Colour crtColor = null;
int[] rgb = null;
int diff = 0;
int minDiff = 999;
for (int i = 0; i < colors.length; i++) {
crtColor = colors[i];
rgb = new int[3];
rgb[0] = crtColor.getDefaultRGB().getRed();
rgb[1] = crtColor.getDefaultRGB().getGreen();
rgb[2] = crtColor.getDefaultRGB().getBlue();
diff = Math.abs(rgb[0] - awtColor.getRed())
+ Math.abs(rgb[1] - awtColor.getGreen())
+ Math.abs(rgb[2] - awtColor.getBlue());
if (diff < minDiff) {
minDiff = diff;
color = crtColor;
}
}
}
if (color == null)
color = Colour.BLACK;
return color;
}
上面代码来自 jasperreports 中的一段代码,正好借用。
原理,由于在Excel只支持256色,需要把HTML中的颜色转化为近似值,处理如上。