按HSV / HSB排序颜色列表

时间:2012-07-25 14:14:35

标签: sorting colors compare hsv hsb

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

我对这些算法非常糟糕,所以任何帮助都会受到赞赏!

1 个答案:

答案 0 :(得分:2)

蛮力方式:

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中的词典排序),但你可能想要更改排序顺序。