2

我在这个网站的媒体框上有一个随机的颜色覆盖。

http://www.reportageborsen.se/reportageborsen/wordpress/

我从 stackoverflow 的伙伴那里得到了一些非常好的帮助,最终得到了这个脚本:

var getRandomInRange = function(min, max) {
    return Math.floor(Math.random() * (max - min + 1)) + min;
};
$('.media-box').each(function() {
    var mediaBox = $(this);
    var mask = mediaBox.find('.mask');
    var hue = 'rgb(' + getRandomInRange(100, 255) + ',' + getRandomInRange(100, 255) + ',' + getRandomInRange(100, 255) + ')';
    mask.css({
            backgroundColor : hue,
        opacity : 0.7            
             });
    mediaBox.hover(function() {
        mask.stop(true, true).fadeIn();
    }, function() {
        mask.stop(true, true).fadeOut();
    });
});​

小提琴链接:http: //jsfiddle.net/b5ZPq/3/

然而,我希望有更多更亮的颜色和更少的灰色。我知道可以使用 HSL 值而不是 RGB 值来完成。

所以我尝试将 css 背景 rgb 值转换为 hsl 值并转换脚本,但我没有让它工作。

var getRandomInRange = function(min, max) {
    return Math.floor(Math.random() * (max - min + 1), 10) + min;
};
$('.media-box').each(function() {
    var mediaBox = $(this);
    var mask = mediaBox.find('.mask');
    var hue = 'hsl(' + getRandomInRange(0, 360) + ',' + getRandomInRange(70, 100) + '%' + getRandomInRange(45, 55) + '%)';
    mask.css({
        backgroundColor: hue,
        opacity: 0.7
    });
    mediaBox.hover(function() {
        mask.stop(true, true).fadeIn();
    }, function() {
        mask.stop(true, true).fadeOut();
    });
});​

http://jsfiddle.net/zolana/Kc9U4/5/ (小提琴,更新,工作:http: //jsfiddle.net/zolana/Kc9U4/9/

(我不是在寻找将所有 RGB 值转换为 HSL 值的脚本(我知道有用于此目的的脚本),而是为这个特定任务提供可靠的脚本。)

4

2 回答 2

4

请记住,当您使用 HSL 颜色(和其他颜色)时,您需要用逗号分隔每个值并使用正确的符号。在这种情况下,它如下所示。

hsl(int色调,int饱和度 ,int亮度

您在第二个参数之后缺少逗号(特别是在百分号之后)。

var hue = 'hsl(' + getRandomInRange(0, 360) + ',' + getRandomInRange(70, 100) + '%,' + getRandomInRange(45, 55) + '%)';

http://jsfiddle.net/b5ZPq/4/

于 2012-12-28T15:14:23.763 回答
1

看看我写的这段代码:

function randomColor(){
    var h = Math.random();
    var s = 0.99;
    var v = 0.99;

    h = h + 0.618033988749895;
    h = h % 1;

    var r, g, b;

    var i = Math.floor(h * 6);
    var f = h * 6 - i;
    var p = v * (1 - s);
    var q = v * (1 - f * s);
    var t = v * (1 - (1 - f) * s);

    switch(i % 6){
        case 0: r = v, g = t, b = p; break;
        case 1: r = q, g = v, b = p; break;
        case 2: r = p, g = v, b = t; break;
        case 3: r = p, g = q, b = v; break;
        case 4: r = t, g = p, b = v; break;
        case 5: r = v, g = p, b = q; break;
    }

    return "rgba("+Math.floor(r*255)+","+ Math.floor(g*255)+","+ Math.floor(b*255)+","+ 0.2+")";
}

它生成一个随机色调值,s 和 v 的恒定值。所以这会返回一个随机明亮的 rgb 颜色。因为我使用了黄金比例,所以颜色也很明亮和不同。如果遇到任何问题,请尝试使用它并返回。

于 2012-12-28T15:16:51.427 回答