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
- JAVA反色计算方法的改进和修正
- 各种反掩码的计算方法
- java日期的计算方法
- 因子和的计算方法
- 校验和的计算方法
- 计算方法之改进的欧拉法计算常微分方程
- Java 5和6的改进
- java中hashcode的计算方法
- java中ArithUtil的计算方法
- >>和<<运算符的计算方法
- Java程序的加密和反加密
- Java程序的加密和反加密
- Java的破解和反破解
- Java程序的加密和反加密
- Java程序的破解和反破解
- Java程序的加密和反加密
- Java程序的加密和反加密
- Java程序的加密和反加密
- 尿酸高但还没发作痛风,用吃药吗?
- c++实践参考:深复制
- 9.2我的数组类
- 第十一周练习,日期时间
- 不可变序列算法示例
- JAVA反色计算方法的改进和修正
- 第13周实践项目4立体类族共有的抽象类
- 第十五周--程序填空
- GDB 调试 Nginx 磨刀不误砍柴工
- 13周 项目二--动物这样叫(1)
- 阅读程序(9)
- 第15周-项目2-洗牌
- 第十三周上机实践项目1(2):分数类中的运算符重载
- 第八周项目三用对象数组操作长方柱类