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

来源:互联网 发布:摩托车违章查询软件 编辑:程序博客网 时间:2024/05/16 17:38

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()));    }

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

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

看来还得根据不同情况做不同的选择才行啊。


0 0
原创粉丝点击