0
点赞
收藏
分享

微信扫一扫

把字符串表达的颜色值转换成java.awt.Color


把字符串表达的颜色值转换成java.awt.Color

RGB颜色值是这样表述的:RRGGBB 六位的16进制来表示“红” "绿" "蓝"各分量。转换的代码是先分析出各分量而后用安全展开式计算出整型数值来创建 Color 的实例。
实际上可以用 java.lang.Integer.parseInt(String , int ) 方法来转换。这个方法的参数列表上有进制的指示,所以转换的代码就很简单了,比如说,转换颜色 "FF00FF"到Color实例,就可这样:

Integer.parseInt("FF00FF", 16);//指示了参数以16进制表达的,要转换出整型值

转换颜色的关键地方已经说明了,那么来作个“工具方法”吧:

/**
* @param c 例如 ff0000 六位的十六进制字符串表示红色
* @return java.awt.Color 对象的实例
* @exception NumberFormatException
*/
public static java.awt.Color parseToColor(final String c)throws NumberFormatException{
    return new java.awt.Color(Integer.parseInt(c, 16));
}


这个方法声明了抛出数字格式化异常,需要调用者抓捕异常。


既然代码这么简单,有必要作成工具方法吗?要知道,方法的调用是要额外的内存和CPU开销的;抓捕异常也是要增加额外开销的。如果程序里仅很少用到,那么可以不必为此转换而包装成一个工具方法。


如果大量要使用颜色转化,并且还想“健壮”——保证不出 NumberFormatException,那么“包装”就得改动一点:



public static Color parseToColor(final String c) {
    Color convertedColor = Color.ORANGE;
    try {
        convertedColor = new Color(Integer.parseInt(c, 16));
    } catch(NumberFormatException e) {
        // codes to deal with this exception
    }
    return convertedColor;
}


显示地抓捕异常,保证在数字格式化异常的时候返回缺省的颜色 (这里设置缺省的颜色是 Color.ORANGE)。调用者也不必要显示地抓捕异常了。



[url]http://chongok.iteye.com/blog/411651[/url]


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


举报

相关推荐

0 条评论