2017-04-24 27 views
-1

我有一个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 
    } 
} 
+3

不能使用['colorArray [I] .equals(matchingColor)'(任何特别的原因https://docs.oracle.com/javase/7/docs/api/java/awt/ Color.html#的equals(java.lang.Object中))? – Tibrogargan

+0

我的比较比较参考而不是对象似乎工作得更好。我不反对它,而只是比较参考。 @Tibrogargan – cuber

+1

为什么不将它们生成某种'Set',并在Set'具有正确数量的元素时停止? –

回答

4

学习您使用的类的API是非常有用的。

for(int i = 0; i < colorArray.length; i++) { 
    // use while in case the color is black/white. (May thrash for few iterations) 
    while (colorArray[i].equals(matchingColor)) { 
     colorArray[i] = (Math.random() < 0.5)?colorArray[i].brighter():colorArray[i].darker(); 
    } 
} 
+0

如何检查colorArray [i] .equals数组中的另一种颜色? – cuber

+0

要检查重复项,最好使用数据类型来存储支持此类功能的元素。原始数组并不是非常有用 - 你必须手动搜索整个事物。一套可能是有用的(如@DawoodibnKareem建议) – Tibrogargan

+0

好的,我会做那部分。 – cuber

0

以下是使用Set来保持唯一性的解决方案。这节省了重新发明所有功能以检查重复项。它利用了这样的事实:如果对象已被添加到集合中,则Set接口的add方法返回true。当然,在封面下,它使用Colorequals方法。

如果发现重复,我们会反复尝试稍微修改Color,通过执行按位异或它的三个分量,直到我们找到一个唯一的分量。

public void deduplicate(Color[] colors) { 
    Set<Color> uniqueColors = new HashSet<>(); 
    for (int which = 0; which < colors.length; which++) { 
     Color originalColor = colors[which]; 
     boolean unique = uniqueColors.add(originalColor); 
     for (int modifyBy = 1; !unique ; modifyBy++) { 
      colors[which] = new Color(
        originalColor.getRed()^modifyBy, 
        originalColor.getGreen()^modifyBy, 
        originalColor.getBlue()^modifyBy); 
      unique = uniqueColors.add(colors[which]); 
     } 
    } 
} 
相关问题