color.js
Summary
No overview generated for 'color.js'
"use strict";
var Color = exports.Color = function Color(r, g, b) {
this.Luminosity = 0.85;
this.Desaturated = 0.4;
if (r instanceof Array) {
this.r = r[0];
this.g = r[1];
this.b = r[2];
} else {
this.r = r;
this.g = g;
this.b = b;
}
};
Color.prototype.update = function(r, g, b) {
this.r = r;
this.g = g;
this.b = b;
};
Color.prototype.hs = function(nStr) {
if (Number(nStr) === 0) {
return "00";
} else if (nStr.length < 2) {
return "0" + nStr;
} else {
return nStr;
}
};
Color.prototype.toString = function() {
var rH = Number(this.r.toFixed()).toString(16);
var gH = Number(this.g.toFixed()).toString(16);
var bH = Number(this.b.toFixed()).toString(16);
return "#" + this.hs(rH) + this.hs(gH) + this.hs(bH);
};
Color.prototype.hsl = function() {
var r = this.r / 255;
var g = this.g / 255;
var b = this.b / 255;
var max = Math.max(r, g, b), min = Math.min(r, g, b);
var h, s, l = (max + min) / 2;
if (max === min) {
h = s = 0;
} else {
var d = max - min;
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
switch (max) {
case r:
h = (g - b) / d + (g < b ? 6 : 0);
break;
case g:
h = (b - r) / d + 2;
break;
case b:
h = (r - g) / d + 4;
break;
}
h /= 6;
}
return [ h, s, l ];
};
Color.prototype.hslToRgb = function(h, s, l) {
function hue2rgb(p, q, t) {
if (t < 0) {
t += 1;
}
if (t > 1) {
t -= 1;
}
if (t < 1 / 6) {
return p + (q - p) * 6 * t;
}
if (t < 1 / 2) {
return q;
}
if (t < 2 / 3) {
return p + (q - p) * (2 / 3 - t) * 6;
}
return p;
}
var r, g, b;
if (s === 0) {
r = g = b = l;
} else {
var q = l < 0.5 ? l * (1 + s) : l + s - l * s;
var p = 2 * l - q;
r = hue2rgb(p, q, h + 1 / 3);
g = hue2rgb(p, q, h);
b = hue2rgb(p, q, h - 1 / 3);
}
return [ r * 255, g * 255, b * 255 ];
};
Color.prototype.hsv = function() {
var r = this.r / 255;
var g = this.g / 255;
var b = this.b / 255;
var max = Math.max(r, g, b), min = Math.min(r, g, b);
var h, s, v = max;
var d = max - min;
s = max === 0 ? 0 : d / max;
if (max === min) {
h = 0;
} else {
switch (max) {
case r:
h = (g - b) / d + (g < b ? 6 : 0);
break;
case g:
h = (b - r) / d + 2;
break;
case b:
h = (r - g) / d + 4;
break;
}
h /= 6;
}
return [ h, s, v ];
};
Color.prototype.hsvToRgb = function(h, s, v) {
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 [ r * 255, g * 255, b * 255 ];
};
Color.prototype.lightColor = function() {
var hslArray = this.hsl();
var h = Number(hslArray[0]);
var s = Number(hslArray[1]) * this.Desaturated;
var l = this.Luminosity;
var desA = this.hslToRgb(h, s, l);
return new Color(desA[0], desA[1], desA[2]);
};
Documentation generated by
JSDoc on Wed Jun 23 09:33:14 2010