随机颜色生成器与色调/饱和度和更多的控制

Random Color Generator with Hue/Saturation and more controls

本文关键字:饱和度 控制 色调 颜色 随机      更新时间:2023-09-26

在这个问题中,我发现了很多有趣的函数来生成随机颜色。

我需要一个随机颜色生成器,接受色相饱和度黑暗范围和我们需要的颜色数量。

实际上我可以写一个随机颜色生成器,但我不太了解颜色数与暗度色调饱和度之间的关系。我想要的功能导出颜色在一个数组。

我还在这里创建了一个jsfiddle文件用于测试:

function get_random_color() {
    var letters = '0123456789ABCDEF'.split('');
    var color = '#';
    for (var i = 0; i < 6; i++ ) {
        color += letters[Math.round(Math.random() * 15)];
    }
    return color;
}
$.each($('div'),function(){
    $(this).css('background-color', get_random_color());
});

谢谢

在支持CSS3的浏览器中,不需要将HSL颜色转换为RGB,因为您可以像这样分配它们:

function rand(min, max) {
    return min + Math.random() * (max - min);
}
function get_random_color() {
    var h = rand(1, 360);
    var s = rand(0, 100);
    var l = rand(0, 100);
    return 'hsl(' + h + ',' + s + '%,' + l + '%)';
}
http://jsfiddle.net/5V8mV/1/

使用该算法,您可以轻松地将颜色限制为蓝色色调,例如:http://jsfiddle.net/DH2Bk/

如果您需要RGB转换算法(例如IE8),您可以直接在规格中找到:http://www.w3.org/TR/css3-color/#hsl-color

HOW TO RETURN hsl.to.rgb(h, s, l):
   SELECT:
     l<=0.5: PUT l*(s+1) IN m2
     ELSE: PUT l+s-l*s IN m2
   PUT l*2-m2 IN m1
   PUT hue.to.rgb(m1, m2, h+1/3) IN r
   PUT hue.to.rgb(m1, m2, h    ) IN g
   PUT hue.to.rgb(m1, m2, h-1/3) IN b
   RETURN (r, g, b)
HOW TO RETURN hue.to.rgb(m1, m2, h): 
   IF h<0: PUT h+1 IN h
   IF h>1: PUT h-1 IN h
   IF h*6<1: RETURN m1+(m2-m1)*h*6
   IF h*2<1: RETURN m2
   IF h*3<2: RETURN m1+(m2-m1)*(2/3-h)*6
   RETURN m1

编辑:

我刚找到一个很好的JS库与更多的选项https://github.com/davidmerfield/randomColor