2015-09-08 11:42:32 +02:00
|
|
|
/* jslint moz: true, bitwise: true */
|
2015-09-06 12:26:50 +02:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
(function(){
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
function getFakeCanvas(window, original){
|
2015-09-06 15:40:34 +02:00
|
|
|
var context = window.HTMLCanvasElement.prototype.getContext.call(original, "2d");
|
2015-09-10 01:35:49 +02:00
|
|
|
var imageData, data, source;
|
|
|
|
if (context){
|
|
|
|
imageData = window.CanvasRenderingContext2D.prototype.getImageData.call(context, 0, 0, original.width, original.height);
|
|
|
|
source = imageData.data;
|
|
|
|
}
|
|
|
|
else {
|
2015-09-10 01:58:38 +02:00
|
|
|
context =
|
|
|
|
window.HTMLCanvasElement.prototype.getContext.call(original, "webgl") ||
|
|
|
|
window.HTMLCanvasElement.prototype.getContext.call(original, "experimental-webgl") ||
|
|
|
|
window.HTMLCanvasElement.prototype.getContext.call(original, "webgl2") ||
|
|
|
|
window.HTMLCanvasElement.prototype.getContext.call(original, "experimental-webgl2");
|
2015-09-10 01:35:49 +02:00
|
|
|
imageData = new window.wrappedJSObject.ImageData(original.width, original.height);
|
|
|
|
source = new window.wrappedJSObject.Uint8Array(imageData.data.length);
|
|
|
|
window.WebGLRenderingContext.prototype.readPixels.call(
|
|
|
|
context,
|
|
|
|
0, 0, original.width, original.height,
|
|
|
|
context.RGBA, context.UNSIGNED_BYTE,
|
|
|
|
source
|
|
|
|
);
|
|
|
|
}
|
2015-09-06 12:26:50 +02:00
|
|
|
var data = imageData.data;
|
2015-09-06 15:40:34 +02:00
|
|
|
|
2015-09-06 12:26:50 +02:00
|
|
|
for (var i = 0, l = data.length; i < l; i += 1){
|
2015-09-10 01:35:49 +02:00
|
|
|
var value = source[i];
|
2015-09-06 15:40:34 +02:00
|
|
|
if (value >= 0x80){
|
2015-09-06 12:26:50 +02:00
|
|
|
value = value ^ Math.floor(Math.random() * 0x20);
|
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
else if (value >= 0x40){
|
2015-09-06 12:26:50 +02:00
|
|
|
value = value ^ Math.floor(Math.random() * 0x10);
|
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
else if (value >= 0x20){
|
2015-09-06 12:26:50 +02:00
|
|
|
value = value ^ Math.floor(Math.random() * 0x08);
|
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
else if (value >= 0x10){
|
2015-09-06 12:26:50 +02:00
|
|
|
value = value ^ Math.floor(Math.random() * 0x04);
|
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
else if (value >= 0x08){
|
2015-09-06 12:26:50 +02:00
|
|
|
value = value ^ Math.floor(Math.random() * 0x02);
|
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
else if (value >= 0x04){
|
2015-09-06 12:26:50 +02:00
|
|
|
value = value ^ Math.floor(Math.random() * 0x01);
|
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
data[i] = value;
|
2015-09-06 12:26:50 +02:00
|
|
|
}
|
2015-09-06 15:40:34 +02:00
|
|
|
var canvas = original.cloneNode(true);
|
2015-09-08 11:42:32 +02:00
|
|
|
context = window.HTMLCanvasElement.prototype.getContext.call(canvas, "2d");
|
2015-09-06 12:26:50 +02:00
|
|
|
context.putImageData(imageData, 0, 0);
|
|
|
|
return canvas;
|
|
|
|
}
|
|
|
|
function getWindow(canvas){
|
|
|
|
return canvas.ownerDocument.defaultView;
|
|
|
|
}
|
|
|
|
// changed functions and their fakes
|
|
|
|
exports.changedFunctions = {
|
|
|
|
getContext: {
|
2015-09-06 15:40:34 +02:00
|
|
|
type: "context",
|
2015-09-06 12:26:50 +02:00
|
|
|
object: "HTMLCanvasElement"
|
|
|
|
},
|
|
|
|
toDataURL: {
|
2015-09-06 15:40:34 +02:00
|
|
|
type: "readout",
|
2015-09-06 12:26:50 +02:00
|
|
|
object: "HTMLCanvasElement",
|
|
|
|
fake: function toDataURL(){
|
|
|
|
var window = getWindow(this);
|
|
|
|
return window.HTMLCanvasElement.prototype.toDataURL.apply(getFakeCanvas(window, this), arguments);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
toBlob: {
|
2015-09-06 15:40:34 +02:00
|
|
|
type: "readout",
|
2015-09-06 12:26:50 +02:00
|
|
|
object: "HTMLCanvasElement",
|
|
|
|
fake: function toBlob(callback){
|
|
|
|
var window = getWindow(this);
|
|
|
|
return window.HTMLCanvasElement.prototype.toBlob.apply(getFakeCanvas(window, this), arguments);
|
|
|
|
},
|
|
|
|
exportOptions: {allowCallbacks: true}
|
|
|
|
},
|
|
|
|
mozGetAsFile: {
|
2015-09-06 15:40:34 +02:00
|
|
|
type: "readout",
|
2015-09-06 12:26:50 +02:00
|
|
|
object: "HTMLCanvasElement",
|
|
|
|
mozGetAsFile: function mozGetAsFile(callbak){
|
|
|
|
var window = getWindow(this);
|
|
|
|
return window.HTMLCanvasElement.prototype.mozGetAsFile.apply(getFakeCanvas(window, this), arguments);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
getImageData: {
|
2015-09-06 15:40:34 +02:00
|
|
|
type: "readout",
|
2015-09-06 12:26:50 +02:00
|
|
|
object: "CanvasRenderingContext2D",
|
|
|
|
fake: function getImageData(sx, sy, sw, sh){
|
|
|
|
var window = getWindow(this.canvas);
|
|
|
|
var context = window.HTMLCanvasElement.prototype.getContext.call(getFakeCanvas(window, this.canvas), "2d");
|
|
|
|
var data = window.CanvasRenderingContext2D.prototype.getImageData.apply(context, arguments).data;
|
|
|
|
|
|
|
|
var imageData = new window.wrappedJSObject.ImageData(sw, sh);
|
|
|
|
for (var i = 0, l = data.length; i < l; i += 1){
|
|
|
|
imageData.data[i] = data[i];
|
|
|
|
}
|
|
|
|
return imageData;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
readPixels: {
|
2015-09-06 15:40:34 +02:00
|
|
|
type: "readout",
|
2015-09-06 12:26:50 +02:00
|
|
|
object: "WebGLRenderingContext",
|
|
|
|
fake: function readPixels(x, y, width, height, format, type, pixels){
|
|
|
|
var window = getWindow(this.canvas);
|
|
|
|
var context = window.HTMLCanvasElement.prototype.getContext.call(getFakeCanvas(window, this.canvas), "webGL");
|
|
|
|
return window.WebGLRenderingContext.prototype.readPixels.apply(context, arguments);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}());
|