我有一个24色的数组。偶尔当我生成它时,我会得到具有完全相同的RGB值的颜色。我想要做的是在数组中找到重复项,并按照1或2更改匹配值。只是为了不再匹配。如何在Java中查找完全相同的颜色数组
这是我的颜色数组。请注意,有3个确切的红色阴影。我希望每个人彼此略有不同。保持R通道相同,但将G和B通道更改为1或2个数字。
Color Array: [java.awt.Color[r=255,g=194,b=23], java.awt.Color[r=255,g=0,b=0], java.awt.Color[r=255,g=0,b=0], java.awt.Color[r=0,g=67,b=255], java.awt.Color[r=0,g=255,b=175], java.awt.Color[r=255,g=13,b=10], java.awt.Color[r=255,g=115,b=43], java.awt.Color[r=2,g=92,b=255], java.awt.Color[r=241,g=219,b=255], java.awt.Color[r=255,g=194,b=0], java.awt.Color[r=231,g=210,b=255], java.awt.Color[r=0,g=43,b=255], java.awt.Color[r=255,g=80,b=0], java.awt.Color[r=255,g=205,b=27], java.awt.Color[r=255,g=0,b=9], java.awt.Color[r=205,g=199,b=255], java.awt.Color[r=0,g=44,b=255], java.awt.Color[r=255,g=0,b=0], java.awt.Color[r=21,g=255,b=219], java.awt.Color[r=255,g=199,b=51], java.awt.Color[r=255,g=82,b=2], java.awt.Color[r=215,g=198,b=255], java.awt.Color[r=0,g=255,b=203], java.awt.Color[r=255,g=98,b=28]]
我在想什么是遍历数组。
for(int i = 0; i < colorArray.length; i++){
if(colorArray[i] == //not sure what this would be equal to as it will be checking all the values in the array) {
colorArray[i].getBlue() = matchingColor.getBlue() += 1;
colorArray[i].getGreen() matchingColor.getGreen() += 2; //These are example values just to make sure that they have no match
}
}
不能使用['colorArray [I] .equals(matchingColor)'(任何特别的原因https://docs.oracle.com/javase/7/docs/api/java/awt/ Color.html#的equals(java.lang.Object中))? – Tibrogargan
我的比较比较参考而不是对象似乎工作得更好。我不反对它,而只是比较参考。 @Tibrogargan – cuber
为什么不将它们生成某种'Set',并在Set'具有正确数量的元素时停止? –