1

在我的应用程序中,我加载了一张图片,我希望能够检测到相似的颜色。因此,如果我选择一种颜色,我希望应用程序能够找到具有相同(或几乎相同)颜色的所有像素。这是我为检测系统编写的内容,该检测系统在鼠标单击点和位图末端之间的垂直方向上进行查看。

for (int y = mouseY; y < m_bitmap.Height; y++)
        {
            Color pixel = m_bitmap.GetPixel(mouseX, y);
            //check if there is another color
            if ((pixel.R > curcolor.R + treshold || pixel.R < curcolor.R - treshold) ||
                (pixel.G > curcolor.G + treshold || pixel.G < curcolor.G - treshold) ||
                (pixel.B > curcolor.B + treshold || pixel.B < curcolor.B - treshold))
            { //YESSSSS!
                if ((y - ytop > minheight)&&(curcolor != Color.White)) //no white, at least 15px height
                {
                    colorlayers.Add(new ColorLayer(curcolor, y - 1, ytop));
                }
                curcolor = pixel;
                ytop = y;
            } 
        }

这会是最好的方法吗?不知何故,它看起来不太适合淡黄色。

4

3 回答 3

2

RGB 是一个3D空间。

各个方向的颜色远阈值与原始阈值不太相似(根据数字相似的可能与人眼不太相似)。

我将使用 HSL(例如)进行检查,其中色调值作为有限的一维范围,例如:

for (int y = mouseY; y < m_bitmap.Height; y++)
{
    Color pixel = m_bitmap.GetPixel(mouseX, y);
    if (Math.Abs(color.GetHue() - curcolor.GetHue()) <= threshold)
    {
        // ...
    }
}

此外,请注意以这种方式使用位图(GetPixel()非常慢,请查看这篇文章以查看更快的替代方案)。

于 2013-10-17T13:26:33.520 回答
0

黄色出现问题的原因可能是 RGB 不是一个感知统一的色彩空间。这意味着,给定颜色空间中两个点/颜色之间的距离,对该颜色距离/差异的感知通常会不同。

也就是说,您可能想要使用其他颜色空间,例如 Adriano 建议的 HSL,或者可能是 Lab。

如果你想坚持RGB,我建议计算欧几里得距离,像这样(我认为它更简单):

float distance = Math.sqrt((pixel.R-curcolor.R)^2 + (pixel.G-curcolor.G)^2 + (pixel.B-curcolor.B)^2);

if(distance < threshold)
{
    // Do what you have to. 
}
于 2013-10-17T13:41:04.870 回答
0

看看Paint.NET 中的魔棒工具是如何工作的可能会很有趣。

这是他们比较两种颜色的方式:

private static bool CheckColor(ColorBgra a, ColorBgra b, int tolerance)
{
  int sum = 0;
  int diff;
  diff = a.R - b.R;
  sum += (1 + diff * diff) * a.A / 256;
  diff = a.G - b.G;
  sum += (1 + diff * diff) * a.A / 256;
  diff = a.B - b.B;
  sum += (1 + diff * diff) * a.A / 256;
  diff = a.A - b.A;
  sum += diff * diff;
  return (sum <= tolerance * tolerance * 4);
}

资源

于 2013-10-17T13:53:49.847 回答