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



我想根据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中使用字典排序),但您可能需要改变排序顺序。

相关内容

  • 没有找到相关文章

最新更新