php – 从一组十六进制颜色获取基本颜色

前端之家收集整理的这篇文章主要介绍了php – 从一组十六进制颜色获取基本颜色前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一套颜色,想把它们分解成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);

如果你想要的话,你可以用八度做一些奇怪的事情,但是只有一小撮颜色才能循环,找到最小的距离才能正常工作.

猜你在找的PHP相关文章