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

本文介绍如何将16进制的RGB颜色值转换为`java.awt.Color`对象。通过`Integer.parseInt()`方法可以实现转换,同时提供了一个处理数字格式异常的工具方法,确保在大量使用时的健壮性。此外,还展示了如何将`Color`对象转换为`jxl.format.Colour`,以便在Excel中使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

把字符串表达的颜色值转换成java.awt.Color
[url]http://hi.baidu.com/hardneedl/item/1d8b975b122dd308e6c4a5da[/url]
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中的颜色转化为近似值,处理如上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值