Color Jumps From Blue To Violette
Solution 1:
To get from one color to another on shortest path Joel's answer is fine, I can't make it better. So I make another approach staying as close as possible to the code you have already since you say first part works fine.
In function setValue()
the beforelast line is else c = 360 - m * 15;
. Change it to:
else c = m * -15;
Now when the sliderValue goes from 12 to 15 the function returns a negative hue from 0 to -45. That way you remove the 'jump' from 0 to 315 and get continously decreasing values when sliderValue increases (and contrarywise). Since now value can be < 0 use adjustValue()
each time you set a value to the canvas (adjustValue()
internally checks for < 0
so you need no extra check).
Then all the code you posted could look like this:
var cur = top.fillColor.hue;
if (cur > 300) cur -= 360;
var dif = cur - setValue();
if (Math.abs(dif) > 41) cur -= Math.round(dif / 1.05);
else {
cur += top.counter_dsg < 20 ? -0.5 : 0.5;
top.counter_dsg += 0.5
}
if (top.counter_dsg > 39) top.counter_dsg = 0;
top.fillColor.hue = adjustValue(cur);
Solution 2:
I hope I correctly answer, but I'm not really sure to understand what you're trying to do. If I understand, you want to have some transitioning effect over a color change, right?
I propose a radically different approach, more "mathematical", fluent. Let's say you want to achieve the color transition within 1 second, regardless how big is the jump from old color to new color. You would just have to determinate a "transition vector", that would be the shortest possible: if the scale goes from 0 to 360, the vector is: (540 + new - old) % 360 - 180.
Why that? The "naive" vector is just (new-old). By adding 360 then modulo 360, we make sure we have a positive number. And by adding 180 (540=180+360) BEFORE modulo, then removing 180 AFTER modulo, we make sure we have a number in range [-180, 180] => which is what we want to get the shortest path.
For instance, with this formula:
- if old=5, new=10 => vector is +5
- if old=350, new=10 => vector is +20
- if old=350, new=340 => vector is -10
Then once you've calculated that vector, you just have to apply it to your color value at each time frame, multiplied by the time factor. For instance:
var v = (540 + newColor - oldColor) % 360 - 180;
var currentColor = oldColor;
var delta = 200; // milliseconds
var timeElapsed = 0;
var timeFrame = 1000; // 1s
var hInt = setInterval(function() {
if (timeElapsed >= timeFrame) {
clearInterval(hInt);
currentColor = newColor;
} else {
timeElapsed += delta;
currentColor += v * delta / timeFrame;
}
}, delta);
"currentColor" will give you the right color over time.
Post a Comment for "Color Jumps From Blue To Violette"