从#FFFFFF格式的颜色转换为 java.awt.Color和 jxl.format.Colour

在以项目中遇到需要把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中的颜色转化为近似值,处理如上。

你可能感兴趣的:(java,html,Excel)