我想从一个 RGB 值中找到一系列颜色

例如,如果给我 rgb(0,100,200),它将给我 rgb(0,0,255) 和 rgb(0,255,255) 之间的所有内容。但不是 rgb(255,0,255)。

类似的rgb(150,50,0)。返回:rgb(255,0,0) 和 rgb(255,255,0)。不是 rgb(255,0,255)。

有道理?

我正在使用 PHP

有帮助吗?

解决方案

您解释的算法基本上是:“一种颜色由两个 RGB 分量组成。设最强的 RGB 分量为 S,另一个分量为 O。创建 255 个变体,其中 S 为 (255),O 的范围为 0 到 255。”

例如。以下所有示例都会产生相同的结果:

a) rgb(0,100,200) 
b) rgb(0,199,200)
c) rgb(0,254,255)
d) rgb(0,1,2)

Result: rgb(0,[0-255],255)

这意味着您只有 6 种变体。

  1. 红色是最大的分量,绿色次大 => rgb(255,[0-255],0)
  2. 红色是最大的分量,蓝色次大 => rgb(255,0,[0-255])
  3. 绿色是最大的分量,红色次大 => rgb([0-255],255,0)
  4. 绿色是最大的分量,蓝色次大 => rgb([0-255],0,255)
  5. 蓝色是最大的分量,红色次大 => rgb([0-255],0,255)
  6. 蓝色是最大的分量,绿色次大 => rgb(0,[0-255],255)

您的算法的意图尚不清楚,所以我猜测您的用例实际上与您所解释的不同。它不处理具有 1 或 3 个分量的颜色(实际上是大多数颜色)。

如果您的目标是找到相似的颜色(例如一定距离内的颜色)有更好的方法。例如,您可以将颜色转换为 HSV 颜色空间(色相、饱和度、值),然后如果 H、S 或 V 分量中的任何一个与原始颜色相差 +/- 10 步,则表示颜色相似。

例如。:

rgb(255,100,0) => hsv(24,100,100)

你的范围是 hsv([14-34],[90-110],[90-110])

其他提示

嗯,不知道我正确理解这一点,但我觉得你说的数字一个比其他两个较高,和值中的一个始终为零。如果是这样的话,你应该能够使用类似于一个简单的if-else语句

if (r > g && r > b) {
  if (g > 0) {
    color1 = rgb(255, 0, 0);
    color2 = rgb(255, 255, 0);
  }
  else {
    color1 = rgb(255, 0, 0);
    color2 = rgb(255, 0, 255);
  }
}
else if (r < g && g > b) {
   .
   .
   .
}

希望这将帮助您与您的问题。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top