mirror of
https://github.com/sorenisanerd/gotty.git
synced 2024-11-14 01:14:25 +00:00
130 lines
4.5 KiB
JavaScript
130 lines
4.5 KiB
JavaScript
|
/*
|
||
|
eyeOS Spice Web Client
|
||
|
Copyright (c) 2015 eyeOS S.L.
|
||
|
|
||
|
Contact Jose Carlos Norte (jose@eyeos.com) for more information about this software.
|
||
|
|
||
|
This program is free software; you can redistribute it and/or modify it under
|
||
|
the terms of the GNU Affero General Public License version 3 as published by the
|
||
|
Free Software Foundation.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||
|
FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
||
|
details.
|
||
|
|
||
|
You should have received a copy of the GNU Affero General Public License
|
||
|
version 3 along with this program in the file "LICENSE". If not, see
|
||
|
<http://www.gnu.org/licenses/agpl-3.0.txt>.
|
||
|
|
||
|
See www.eyeos.org for more details. All requests should be sent to licensing@eyeos.org
|
||
|
|
||
|
The interactive user interfaces in modified source and object code versions
|
||
|
of this program must display Appropriate Legal Notices, as required under
|
||
|
Section 5 of the GNU Affero General Public License version 3.
|
||
|
|
||
|
In accordance with Section 7(b) of the GNU Affero General Public License version 3,
|
||
|
these Appropriate Legal Notices must retain the display of the "Powered by
|
||
|
eyeos" logo and retain the original copyright notice. If the display of the
|
||
|
logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices
|
||
|
must display the words "Powered by eyeos" and retain the original copyright notice.
|
||
|
*/
|
||
|
|
||
|
wdi.RasterOperation = {
|
||
|
|
||
|
process: function(rop, sourceImg, destImg) {//sourceImg could be brush or image (both imageData)
|
||
|
var result = null;
|
||
|
if (rop & wdi.SpiceRopd.SPICE_ROPD_INVERS_SRC) {
|
||
|
sourceImg = this.invert(sourceImg);
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_INVERS_BRUSH) {
|
||
|
sourceImg = this.invert(sourceImg);
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_INVERS_DEST) {
|
||
|
destImg = this.invert(destImg);
|
||
|
}
|
||
|
|
||
|
if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_PUT) {
|
||
|
return sourceImg;
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_OR) {
|
||
|
result = this.boolOp(sourceImg, destImg, 'or');
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_AND) {
|
||
|
result = this.boolOp(sourceImg, destImg, 'and');
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_XOR) {
|
||
|
result = this.boolOp(sourceImg, destImg, 'xor');
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_BLACKNESS) {
|
||
|
result = this.lightness(destImg, 'b');
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_WHITENESS) {
|
||
|
result = this.lightness(destImg);
|
||
|
} else if (rop & wdi.SpiceRopd.SPICE_ROPD_OP_INVERS) {
|
||
|
result = this.invert(destImg);
|
||
|
}
|
||
|
|
||
|
if (rop & wdi.SpiceRopd.SPICE_ROPD_INVERS_RES) {
|
||
|
return this.invert(result);
|
||
|
} else {
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
},
|
||
|
|
||
|
flip: function(sourceImg) {
|
||
|
sourceImg = wdi.Flipper.flip(sourceImg);
|
||
|
return sourceImg;
|
||
|
},
|
||
|
|
||
|
invert: function(sourceImg) {
|
||
|
sourceImg = $(sourceImg).pixastic('invert')[0];
|
||
|
|
||
|
return sourceImg;
|
||
|
},
|
||
|
|
||
|
lightness: function(sourceImg, ratio) {
|
||
|
var ratio = ratio==='b'?-100:100;
|
||
|
sourceImg = $(sourceImg).pixastic('hsl', {hue:30,saturation:20,lightness:ratio})[0];
|
||
|
|
||
|
return sourceImg;
|
||
|
},
|
||
|
|
||
|
boolOp: function(sourceImg, destImg, op) {
|
||
|
//or and and xor implemented without globalcomposition
|
||
|
//because it is really buggy
|
||
|
|
||
|
var source = wdi.graphics.getDataFromImage(sourceImg).data;
|
||
|
var dest = wdi.graphics.getDataFromImage(destImg).data;
|
||
|
|
||
|
var length = source.length-1;
|
||
|
var tmp_canvas = wdi.graphics.getNewTmpCanvas(sourceImg.width, sourceImg.height);
|
||
|
var tmp_context = tmp_canvas.getContext('2d');
|
||
|
|
||
|
var resultImageData = tmp_context.createImageData(sourceImg.width, sourceImg.height);
|
||
|
var result = resultImageData.data;
|
||
|
|
||
|
if(op === 'or') {
|
||
|
while(length > 0) {
|
||
|
resultImageData.data[length] = 255;
|
||
|
result[length-1] = source[length-1] | dest[length-1];
|
||
|
result[length-2] = source[length-2] | dest[length-2];
|
||
|
result[length-3] = source[length-3] | dest[length-3];
|
||
|
length-=4;
|
||
|
}
|
||
|
} else if(op === 'and') {
|
||
|
while(length > 0) {
|
||
|
resultImageData.data[length] = 255;
|
||
|
result[length-1] = source[length-1] & dest[length-1];
|
||
|
result[length-2] = source[length-2] & dest[length-2];
|
||
|
result[length-3] = source[length-3] & dest[length-3];
|
||
|
length-=4;
|
||
|
}
|
||
|
} else if(op === 'xor') {
|
||
|
while(length > 0) {
|
||
|
resultImageData.data[length] = 255;
|
||
|
result[length-1] = source[length-1] ^ dest[length-1];
|
||
|
result[length-2] = source[length-2] ^ dest[length-2];
|
||
|
result[length-3] = source[length-3] ^ dest[length-3];
|
||
|
length-=4;
|
||
|
}
|
||
|
}
|
||
|
tmp_context.putImageData(resultImageData, 0, 0);
|
||
|
return tmp_canvas;
|
||
|
}
|
||
|
};
|