1
0
mirror of https://github.com/kkapsner/CanvasBlocker synced 2025-01-18 17:38:46 +01:00
CanvasBlocker/lib/modifiedAPI.js

121 lines
3.9 KiB
JavaScript
Raw Normal View History

2016-08-06 19:17:36 +02:00
/* jslint moz: true */
/* 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";
2016-08-06 19:17:36 +02:00
var randomSupply = null;
function getFakeCanvas(window, original){
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
);
}
2016-02-13 12:48:22 +01:00
data = imageData.data;
2016-05-14 19:12:45 +02:00
var l = data.length;
2016-08-06 19:17:36 +02:00
var rng = randomSupply.getRng(l, window);
for (var i = 0; i < l; i += 1){
2016-08-06 19:17:36 +02:00
data[i] = rng(source[i], i);
}
var canvas = original.cloneNode(true);
2015-09-08 11:42:32 +02:00
context = window.HTMLCanvasElement.prototype.getContext.call(canvas, "2d");
context.putImageData(imageData, 0, 0);
return canvas;
}
function getWindow(canvas){
return canvas.ownerDocument.defaultView;
}
2016-08-06 19:17:36 +02:00
exports.setRandomSupply = function(supply){
randomSupply = supply;
};
// changed functions and their fakes
exports.changedFunctions = {
getContext: {
type: "context",
object: "HTMLCanvasElement"
},
toDataURL: {
type: "readout",
object: "HTMLCanvasElement",
fake: function toDataURL(){
var window = getWindow(this);
return window.HTMLCanvasElement.prototype.toDataURL.apply(getFakeCanvas(window, this), arguments);
}
},
toBlob: {
type: "readout",
object: "HTMLCanvasElement",
fake: function toBlob(callback){
var window = getWindow(this);
return window.HTMLCanvasElement.prototype.toBlob.apply(getFakeCanvas(window, this), arguments);
},
exportOptions: {allowCallbacks: true}
},
mozGetAsFile: {
type: "readout",
object: "HTMLCanvasElement",
mozGetAsFile: function mozGetAsFile(callback){
var window = getWindow(this);
return window.HTMLCanvasElement.prototype.mozGetAsFile.apply(getFakeCanvas(window, this), arguments);
}
},
getImageData: {
type: "readout",
object: "CanvasRenderingContext2D",
fakeGenerator: function(prefs, notify){
2016-05-10 08:01:21 +02:00
var maxSize = prefs("maxFakeSize") || Number.POSITIVE_INFINITY;
return function getImageData(sx, sy, sw, sh){
var window = getWindow(this.canvas);
var context;
if (sw * sh > maxSize){
context = this;
}
else {
notify();
context = window.HTMLCanvasElement.prototype.getContext.call(
2016-05-10 08:01:21 +02:00
getFakeCanvas(window, this.canvas),
"2d"
);
}
2016-05-10 08:01:21 +02:00
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;
2016-08-06 19:17:36 +02:00
};
}
},
readPixels: {
type: "readout",
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);
}
}
};
}());