gpt4 book ai didi

sorting - 按 HSV/HSB 对颜色列表进行排序

转载 作者:行者123 更新时间:2023-12-04 05:38:10 25 4
gpt4 key购买 nike

我希望通过 HSV/HSB 值对很长的颜色列表进行排序。我想按色调对它们进行排序,然后是周六,然后是明亮。我真正需要的只是一种方法来根据 HSV 的顺序判断一种颜色是“之前”还是“之后”,因为我只是要在 Java 中进行 compareTo() 并使用 TreeSet 进行排序。在 Java 中,HSV 值都存储为浮点数。

我对这些算法很糟糕,所以任何帮助都将不胜感激!

最佳答案

蛮力方法:

public final class ColorComparator implements Comparator<Color> {
@Override
public int compare(Color c1, Color c2) {
float[] hsb1 = Color.RGBtoHSB(c1.getRed(), c1.getGreen(), c1.getBlue(), null);
float[] hsb2 = Color.RGBtoHSB(c2.getRed(), c2.getGreen(), c2.getBlue(), null);
if (hsb1[0] < hsb2[0])
return -1;
if (hsb1[0] > hsb2[0])
return 1;
if (hsb1[1] < hsb2[1])
return -1;
if (hsb1[1] > hsb2[1])
return 1;
if (hsb1[2] < hsb2[2])
return -1;
if (hsb1[2] > hsb2[2])
return 1;
return 0;
}
}

如果您可以使用 Google Guava 库,一个非常简单、无需考虑的方法是:
public final class ColorComparator extends Ordering<Color> {
@Override
public int compare(Color c1, Color c2) {
float[] hsb1 = Color.RGBtoHSB(c1.getRed(), c1.getGreen(), c1.getBlue(), null);
float[] hsb2 = Color.RGBtoHSB(c2.getRed(), c2.getGreen(), c2.getBlue(), null);
return ComparisonChain.start().compare(hsb1[0], hsb2[0]).compare(hsb1[1], hsb2[1])
.compare(hsb1[2], hsb2[2]).result();
}
}

我会说只是遍历数组并比较它们(或在 Guava 中使用字典顺序),但您可能想要更改排序顺序。

关于sorting - 按 HSV/HSB 对颜色列表进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11651781/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com