我有一套颜色,想把它们分解成10到20种基色.
这不应该是传递进来的托盘,而是独立于所传递的东西.所以如果使用的图像只是各种各样的红色,那么它只会返回红色,可能会带有浅/深红色.
EG:我所拥有的颜色是下面的框,以输出为例.所以从21种颜色来看,这个例子中的列表是8个.
上述十六进制值:
#000000 #ffffff #003e9f #d61517 #00a7bd #001070 #a0210c #dc9103 #e6151e #fdfdfd #011171 #fbfd10 #ffc500 #fdc605 #e6141d #faf703 #544b20 #796a3a #7a6b3a
最终输出可能是这个色轮的外圈
提前选择您的基础颜色并制作阵列 – 您可以在色轮的外圈使用12.使用关联数组作为输出的集合:对于每个输入颜色,找到最接近的基本颜色,并将其作为输出数组的键添加.然后返回该数组的键.
要找到颜色距离,您可以将颜色视为三维空间(x,y,z)=(r,g,b)中的点,并使用欧几里得距离.从十六进制字符串中提取组件后,就像这样:
$dr = $r2 - $r1; $dg = $g2 - $g1; $db = $b2 - $b1; $dist = sqrt($dr * $dr + $dg * $dg + $db * $db);
如果你想要的话,你可以用八度做一些奇怪的事情,但是只有一小撮颜色才能循环,找到最小的距离才能正常工作.