Improved performance for getImageData.

This commit is contained in:
kkapsner 2016-12-03 17:29:30 +01:00
parent 7b7583afe0
commit 0eeaf84826
1 changed files with 3 additions and 10 deletions

View File

@ -191,24 +191,17 @@
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){
return original.call(this, sx, sy, sw, sh);
return original.apply(this, window.Array.from(arguments));
}
else {
notify("fakedReadout");
context = window.HTMLCanvasElement.prototype.getContext.call(
var context = window.HTMLCanvasElement.prototype.getContext.call(
getFakeCanvas(window, this.canvas),
"2d"
);
return original.apply(context, window.Array.from(arguments));
}
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;
};
}
},