题
我想从一个 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 种变体。
- 红色是最大的分量,绿色次大 => rgb(255,[0-255],0)
- 红色是最大的分量,蓝色次大 => rgb(255,0,[0-255])
- 绿色是最大的分量,红色次大 => rgb([0-255],255,0)
- 绿色是最大的分量,蓝色次大 => rgb([0-255],0,255)
- 蓝色是最大的分量,红色次大 => rgb([0-255],0,255)
- 蓝色是最大的分量,绿色次大 => 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) {
.
.
.
}
希望这将帮助您与您的问题。
不隶属于 StackOverflow