From d82a31648f38271d2e662f8a7f8d1610ec99df59 Mon Sep 17 00:00:00 2001 From: Klaus Weidner Date: Tue, 11 Jun 2013 13:18:58 -0700 Subject: [PATCH] Only resize canvas if the size changed. Resizing the canvas erases it, and Dygraphs had skipped the redraw when it thought it wasn't necessary, leading to blank graphs after a redundant .resize() call. --- auto_tests/tests/resize.js | 23 +++++++++++++++-------- dygraph.js | 5 +++-- 2 files changed, 18 insertions(+), 10 deletions(-) diff --git a/auto_tests/tests/resize.js b/auto_tests/tests/resize.js index 5d68b1b..4762892 100644 --- a/auto_tests/tests/resize.js +++ b/auto_tests/tests/resize.js @@ -6,13 +6,13 @@ var ResizeTestCase = TestCase("resize"); ResizeTestCase.data = - "Date,Y\n" + - "2010/01/01,100\n" + - "2010/02/01,200\n" + - "2010/03/01,300\n" + - "2010/04/01,400\n" + - "2010/05/01,300\n" + - "2010/06/01,100\n"; + "X,Y\n" + + "1,100\n" + + "2,200\n" + + "3,300\n" + + "4,400\n" + + "5,300\n" + + "6,100\n"; ResizeTestCase.prototype.setUp = function() { document.body.innerHTML = "
"; @@ -83,11 +83,18 @@ ResizeTestCase.prototype.testHiddenDivWithResize = function() { div.style.width = '400px'; div.style.height = '300px'; - var g = new Dygraph(div, ResizeTestCase.data, {}); + var g = new Dygraph(div, ResizeTestCase.data, {strokeWidth: 3}); div.style.display = ''; g.resize(); area = g.getArea(); assertTrue(area.w > 0); assertTrue(area.h > 0); + + // Regression test: check that graph remains visible after no-op resize. + g.resize(); + var x = Math.floor(g.toDomXCoord(2)); + var y = Math.floor(g.toDomYCoord(200)); + assertEquals("Unexpected grid color found at pixel: x: " + x + " y: " + y, + [0, 128, 128, 255], Util.samplePixel(g.hidden_, x, y)); }; diff --git a/dygraph.js b/dygraph.js index 442c00c..db9a8bf 100644 --- a/dygraph.js +++ b/dygraph.js @@ -3707,9 +3707,10 @@ Dygraph.prototype.resize = function(width, height) { this.height_ = this.maindiv_.clientHeight; } - this.resizeElements_(); - if (old_width != this.width_ || old_height != this.height_) { + // Resizing a canvas erases it, even when the size doesn't change, so + // any resize needs to be followed by a redraw. + this.resizeElements_(); this.predraw_(); } -- 2.7.4