您的位置:首页 > 编程语言 > Java开发

JAVA反色计算方法的改进和修正

2016-06-09 08:52 288 查看
Java中计算Color的相反颜色,经常使用下面的方法

public static Color Color2Contrary(Color color) {
return new Color(255 - color.getRed(), 255 - color.getGreen(), 255 - color.getBlue());
}


但这个方法是错误的。比如一个颜色的Red颜色值是127,根据上面的计算,其反色是255-127=128,这样计算出来的颜色根本就不是反色。所以上面的算法不对,应该进行改进和修正。

我改进的思路是这样的:我们将255和某颜色分量的差分为四个区间,0—64,65—127,128—191,192—255。如果差值在第1、4两个区间,说明差值超过了127,直接使用该差值;如果差值在第2个区间,说明差值小于127 ,就扩大差值,即在差值基础上再减去64 ,如果差值在第3个区间,扩大差值,即在差值基础上再加上64 。

改进的用计算各颜色反色的代码如下:

public static int CC(int c){
int cc = 255 - c;
if(cc>64 && cc<128)
cc-=64;
else if(cc>=128 && cc<192)
cc+=64;
return cc;
}
public static Color Color2Contrary2(Color color) {
return new Color(CC(color.getRed()), CC(color.getGreen()), CC(color.getBlue()));
}

下午我又仔细想了一下上面的算法,也有问题。如果用上面的方法来反转图片颜色,明显会出问题。

我的程序里的需求是要根据前景色自动选择背景色,所以对我的程序是适合的。因为如果还用第一种方法,当图片是灰色时,前景色背景色会一样,图片就看不清了。

看来还得根据不同情况做不同的选择才行啊。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 反色 算法 修正