我有一个包含 R、G、B 值的颜色列表。下面使用“Color.rgb(R,G,B)”显示了一些数据。 然后我进行图像处理,当用户触摸图像上的某处时,我会得到该触摸像素的 RGB 值。如何从我的颜色列表中搜索此 RGB 值。 搜索函数应该是:如果 RGB 存在于列表返回位置或值。如果 RGB 不存在,则返回列表中最接近的值。 我的搜索功能是:
List<Colors> colors;
touchedRGB = bitmap.getPixel(x, y);
for (int i = 0; i < colors.size(); i++) {
Colors color=colors.get(i);
if (touchedRGB==Color.rgb(color.getRcolor(),color.getGcolor(), color.getBcolor())) {
Log.v("OK", "Color found at:"+i);
}
}
它只检查并返回颜色是否不存在最接近的颜色。 这是颜色列表的代码:
public class Colors {
public int rowid;
public int Rcolor;
public int Gcolor;
public int Bcolor;
public int RGB;
public int getRowid() {
return rowid;
}
public void setRowid(int rowid) {
this.rowid = rowid;
}
public int getRcolor() {
return Rcolor;
}
public void setRcolor(int Rcolor) {
this.Rcolor = Rcolor;
}
public int getGcolor() {
return Gcolor;
}
public void setGcolor(int Gcolor) {
this.Gcolor = Gcolor;
}
public int getBcolor() {
return Bcolor;
}
public void setBcolor(int Bcolor) {
this.Bcolor = Bcolor;
}
}
日志猫:
06-02 04:40:59.911: V/Color(1539): RGB:-2064 R:255 G:247 B:240
06-02 04:40:59.921: V/Color(1539): RGB:-139303 R:253 G:223 B:217
06-02 04:40:59.981: V/Color(1539): RGB:-147017 R:253 G:193 B:183
06-02 04:41:00.031: V/Color(1539): RGB:-352102 R:250 G:160 B:154
06-02 04:41:00.121: V/Color(1539): RGB:-555139 R:247 G:135 B:125
06-02 04:41:00.171: V/Color(1539): RGB:-2136478 R:223 G:102 B:98
06-02 04:41:00.181: V/Color(1539): RGB:-3781045 R:198 G:78 B:75
06-02 04:41:00.221: V/Color(1539): RGB:-197923 R:252 G:250 B:221
06-02 04:41:00.361: V/Color(1539): RGB:-3403 R:255 G:242 B:181
最佳答案
创建一个“距离”函数来比较 2 种颜色并给出距离。相同颜色的距离为 0。
根据“最接近的颜色”对您的含义,有多种实现距离的方法。最简单的方法是只使用 RGB 差异的总和:
public int Distance(Color a, Color b) {
return Math.Abs(a.r - b.r) + Math.Abs(a.g - b.g) + Math.Abs(a.b - b.b);
}
或者您可以将 RGB 解释为 3D 空间中的一个点并获取几何距离,它看起来像这样:
public double Distance(Color a, Color b) {
return Math.Sqrt(Math.Pow(a.r - b.r, 2) + Math.Pow(a.g - b.g, 2) + Math.Pow(a.b - b.b, 2));
}
这对于大多数简单的应用程序来说通常已经足够好了。如果您想要更真实的比较,您可能会将 RGB 颜色转换为类似 HSV 的颜色,并主要基于色调进行比较。
关于android - 从颜色列表中查找最接近的颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23990802/