remove objects, speed up processing
This commit is contained in:
parent
b5d19780b2
commit
e4a057b990
1 changed files with 28 additions and 32 deletions
60
js/franz.js
60
js/franz.js
|
|
@ -4,7 +4,7 @@
|
||||||
* @Author Dominick Pham (http://twitter.com/enotionz)
|
* @Author Dominick Pham (http://twitter.com/enotionz)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Define some basic prototypes that we'll require later... */
|
/* Define some basic prototypes that we'll require later.. */
|
||||||
|
|
||||||
Array.prototype.swap = function(a, b) {
|
Array.prototype.swap = function(a, b) {
|
||||||
var tmp = this[a];
|
var tmp = this[a];
|
||||||
|
|
@ -22,20 +22,16 @@ var franz = {
|
||||||
ctx: {},
|
ctx: {},
|
||||||
img: {},
|
img: {},
|
||||||
|
|
||||||
rgb: {
|
alpha: [],
|
||||||
alpha: [],
|
red: [],
|
||||||
red: [],
|
green: [],
|
||||||
green: [],
|
blue: [],
|
||||||
blue: []
|
|
||||||
},
|
|
||||||
|
|
||||||
hsvl: {
|
hue: [],
|
||||||
hue: [],
|
satV: [],
|
||||||
satV: [],
|
value: [],
|
||||||
value: [],
|
satL: [],
|
||||||
satL: [],
|
light: [],
|
||||||
light: []
|
|
||||||
},
|
|
||||||
|
|
||||||
origIndex: [],
|
origIndex: [],
|
||||||
|
|
||||||
|
|
@ -79,10 +75,10 @@ var franz = {
|
||||||
var imageData = extra_ctx.getImageData(1, 1, 18, 18).data;
|
var imageData = extra_ctx.getImageData(1, 1, 18, 18).data;
|
||||||
|
|
||||||
for(var i = 0; i*4 < imageData.length; i++) {
|
for(var i = 0; i*4 < imageData.length; i++) {
|
||||||
franz.rgb.red[i] = imageData[i*4];
|
franz.red[i] = imageData[i*4];
|
||||||
franz.rgb.green[i] = imageData[i*4 + 1];
|
franz.green[i] = imageData[i*4 + 1];
|
||||||
franz.rgb.blue[i] = imageData[i*4 + 2];
|
franz.blue[i] = imageData[i*4 + 2];
|
||||||
franz.rgb.alpha[i] = imageData[i*4 + 3];
|
franz.alpha[i] = imageData[i*4 + 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get hue sat val array */
|
/* get hue sat val array */
|
||||||
|
|
@ -98,13 +94,13 @@ var franz = {
|
||||||
RGBtoHSVHL: function() {
|
RGBtoHSVHL: function() {
|
||||||
var min, max;
|
var min, max;
|
||||||
|
|
||||||
for(var i = 0; i < franz.rgb.alpha.length; i++) {
|
for(var i = 0; i < franz.alpha.length; i++) {
|
||||||
franz.hsvl.value[i] = franz.getValHSV(franz.rgb.red[i],franz.rgb.green[i],franz.rgb.blue[i]);
|
franz.value[i] = franz.getValHSV(franz.red[i],franz.green[i],franz.blue[i]);
|
||||||
franz.hsvl.satV[i] = franz.getSatHSV(franz.rgb.red[i],franz.rgb.green[i],franz.rgb.blue[i]);
|
franz.satV[i] = franz.getSatHSV(franz.red[i],franz.green[i],franz.blue[i]);
|
||||||
franz.hsvl.hue[i] = franz.getHue(franz.rgb.red[i],franz.rgb.green[i],franz.rgb.blue[i]);
|
franz.hue[i] = franz.getHue(franz.red[i],franz.green[i],franz.blue[i]);
|
||||||
|
|
||||||
franz.hsvl.satL[i] = franz.getSatHSL(franz.rgb.red[i],franz.rgb.green[i],franz.rgb.blue[i]);
|
franz.satL[i] = franz.getSatHSL(franz.red[i],franz.green[i],franz.blue[i]);
|
||||||
franz.hsvl.light[i] = franz.getLightHSL(franz.rgb.red[i],franz.rgb.green[i],franz.rgb.blue[i]);
|
franz.light[i] = franz.getLightHSL(franz.red[i],franz.green[i],franz.blue[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return false
|
return false
|
||||||
|
|
@ -168,8 +164,8 @@ var franz = {
|
||||||
displayColors: function(order_array) {
|
displayColors: function(order_array) {
|
||||||
var docStr = "";
|
var docStr = "";
|
||||||
|
|
||||||
for(var i = 0; i < franz.rgb.alpha.length; i++) {
|
for(var i = 0; i < franz.alpha.length; i++) {
|
||||||
docStr += '<div class="color_box" style="background-color: rgb(' + franz.rgb.red[order_array[i]] + ', ' + franz.rgb.green[order_array[i]] + ',' + franz.rgb.blue[order_array[i]] + ');"></div>';
|
docStr += '<div class="color_box" style="background-color: rgb(' + franz.red[order_array[i]] + ', ' + franz.green[order_array[i]] + ',' + franz.blue[order_array[i]] + ');"></div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
document.getElementById("log_colors").innerHTML = docStr;
|
document.getElementById("log_colors").innerHTML = docStr;
|
||||||
|
|
@ -182,7 +178,7 @@ var franz = {
|
||||||
resetIndex: function() {
|
resetIndex: function() {
|
||||||
/* keep track of original index so we don't have to revert
|
/* keep track of original index so we don't have to revert
|
||||||
back to RGB just to display output */
|
back to RGB just to display output */
|
||||||
for (var i=0; i < franz.rgb.alpha.length; i++) {
|
for (var i=0; i < franz.alpha.length; i++) {
|
||||||
franz.origIndex[i] = i;
|
franz.origIndex[i] = i;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -195,31 +191,31 @@ var franz = {
|
||||||
},
|
},
|
||||||
|
|
||||||
displayHue: function() {
|
displayHue: function() {
|
||||||
franz.indexSort(franz.clone(franz.hsvl.hue), 0, franz.rgb.alpha.length);
|
franz.indexSort(franz.clone(franz.hue), 0, franz.alpha.length);
|
||||||
franz.displayColors(franz.origIndex);
|
franz.displayColors(franz.origIndex);
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
displaySat: function() {
|
displaySat: function() {
|
||||||
franz.indexSort(franz.clone(franz.hsvl.satV), 0, franz.rgb.alpha.length);
|
franz.indexSort(franz.clone(franz.satV), 0, franz.alpha.length);
|
||||||
franz.displayColors(franz.origIndex);
|
franz.displayColors(franz.origIndex);
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
displayVal: function() {
|
displayVal: function() {
|
||||||
franz.indexSort(franz.clone(franz.hsvl.value), 0, franz.rgb.alpha.length);
|
franz.indexSort(franz.clone(franz.value), 0, franz.alpha.length);
|
||||||
franz.displayColors(franz.origIndex);
|
franz.displayColors(franz.origIndex);
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
displaySatL: function() {
|
displaySatL: function() {
|
||||||
franz.indexSort(franz.clone(franz.hsvl.satL), 0, franz.rgb.alpha.length);
|
franz.indexSort(franz.clone(franz.satL), 0, franz.alpha.length);
|
||||||
franz.displayColors(franz.origIndex);
|
franz.displayColors(franz.origIndex);
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
displayLight: function() {
|
displayLight: function() {
|
||||||
franz.indexSort(franz.clone(franz.hsvl.light), 0, franz.rgb.alpha.length);
|
franz.indexSort(franz.clone(franz.light), 0, franz.alpha.length);
|
||||||
franz.displayColors(franz.origIndex);
|
franz.displayColors(franz.origIndex);
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
|
||||||
Reference in a new issue