从#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中的颜色转化为近似值,处理如上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值