根据动态值生成渐变步骤,包括小数

时间:2016-10-18 14:18:17

标签: javascript jquery css hsl

基于this questionfabulous answer for values from 0..1,我尝试修改函数以包含最小值和最大值。

function getColor(value, min, max){
    var hue=((max-(value-min))*120).toString(10);
    return ["hsl(",hue,",100%,50%)"].join("");
}

对于整数而言似乎工作得很好,但对于小数则没有那么多。例如,这些工作按预期进行:

var value=42;
var d=document.createElement('div');
d.textContent="value="+value + " (this should be green)";
d.style.backgroundColor=getColor(value,42,100);
document.body.appendChild(d);

var value=42;
var d=document.createElement('div');
d.textContent="value="+value + " (this should be red)";
d.style.backgroundColor=getColor(value,0,42);
document.body.appendChild(d);

但这些不是:

var value=0.1;
var d=document.createElement('div');
d.textContent="value="+value + " (this should be green)";
d.style.backgroundColor=getColor(value,0,90);
document.body.appendChild(d);

var value=0.1;
var d=document.createElement('div');
d.textContent="value="+value + " (this should be green)";
d.style.backgroundColor=getColor(value,0,5);
document.body.appendChild(d);

最后一个实际上是蓝色的...... Here is a fiddle。如何将其更改为适用于所有4种方案?

1 个答案:

答案 0 :(得分:2)

这看起来效果很好:

function getColor(value, min, max){
    if (value > max) value = max;
    var v = (value-min) / (max-min);
    var hue=((1 - v)*120).toString(10);
    return ["hsl(",hue,",100%,50%)"].join("");
}

编辑:根据以下评论进行调整