基于动态值生成渐变步骤,包括小数

编程入门 行业动态 更新时间:2024-10-23 07:36:43
本文介绍了基于动态值生成渐变步骤,包括小数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

根据此问题,其中有从值0..1的神话答案,我试图修改函数包括最小和最大值。

Based on this question, which has a fabulous answer for values from 0..1, I tried to modify the function to include the min and max values.

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

它似乎对整数工作正常,但不是小数。例如,这些工作按预期工作:

It seems to work fine for whole numbers, but not so much for decimals. For instance, these work as expected:

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);

最后一个实际上是蓝色... 这是一个小提琴。

The last one is actually blue... Here is a fiddle. How can I change this to work with all 4 scenarios?

推荐答案

这看起来效果很好:

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(""); }

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

edit: adjusted based on comments below

更多推荐

基于动态值生成渐变步骤,包括小数

本文发布于:2023-11-23 01:33:10,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1619634.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:小数   步骤   动态

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!