Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(942)

Unified Diff: chrome/test/data/third_party/spaceport/js/sprites/renderers/canvasDrawImagePartialClear.js

Issue 10154006: Add test data for spaceport benchmark. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/test/data/third_party/spaceport/js/sprites/renderers/canvasDrawImagePartialClear.js
diff --git a/chrome/test/data/third_party/spaceport/js/sprites/renderers/canvasDrawImagePartialClear.js b/chrome/test/data/third_party/spaceport/js/sprites/renderers/canvasDrawImagePartialClear.js
new file mode 100644
index 0000000000000000000000000000000000000000..88992f29f8f2aaf785059a26fca84652e4cbfd08
--- /dev/null
+++ b/chrome/test/data/third_party/spaceport/js/sprites/renderers/canvasDrawImagePartialClear.js
@@ -0,0 +1,68 @@
+define([ 'util/ensureCallback', 'sprites/canvas' ], function (ensureCallback, canvas) {
+ function RenderContext(sourceData, frameData) {
+ this.sourceData = sourceData;
+ this.frameData = frameData;
+
+ this.previousTransforms = null;
+ this.previousFrameIndex = null;
+
+ this.canvas = canvas();
+
+ this.context = this.canvas.getContext('2d');
+ this.context.globalCompositeOperation = 'source-over';
+ }
+
+ RenderContext.prototype.load = function load(callback) {
+ callback = ensureCallback(callback);
+
+ document.body.appendChild(this.canvas);
+
+ callback(null);
+ };
+
+ RenderContext.prototype.unload = function unload() {
+ if (this.canvas.parentNode) {
+ this.canvas.parentNode.removeChild(this.canvas);
+ }
+ };
+
+ RenderContext.prototype.clear = function clear() {
+ this.canvas.width = this.canvas.width;
+ this.previousTransforms = null;
+ };
+
+ RenderContext.prototype.renderFrame = function renderFrame(frameIndex) {
+ var context = this.context;
+ var sourceData = this.sourceData;
+
+ var transforms = this.frameData[frameIndex];
+ var count = transforms.length;
+ var i;
+
+ var previousTransforms = this.previousTransforms;
+ if (previousTransforms) {
+ // We clear with an extra 1px border to clear smoothed edges
+ var frameInfo = sourceData.getFrameInfo(this.previousFrameIndex);
+ var width = frameInfo.width + 2;
+ var height = frameInfo.height + 2;
+ for (i = 0; i < count; ++i) {
+ var m = previousTransforms[i].matrix;
+ context.setTransform(m[0], m[1], m[3], m[4], m[2], m[5]);
+ context.clearRect(-1, -1, width, height);
+ }
+ }
+
+ for (i = 0; i < count; ++i) {
+ var m = transforms[i].matrix;
+ context.setTransform(m[0], m[1], m[3], m[4], m[2], m[5]);
+ sourceData.drawToCanvas(context, 0, 0, frameIndex);
+ }
+
+ this.previousTransforms = transforms;
+ this.previousFrameIndex = frameIndex;
+ };
+
+ return function (element, frameData) {
+ return new RenderContext(element, frameData);
+ };
+});

Powered by Google App Engine
This is Rietveld 408576698