From 3946cdc5f827acc25495faa6c085486d65bf88a0 Mon Sep 17 00:00:00 2001 From: adroitwhiz Date: Sat, 16 May 2020 03:56:12 -0400 Subject: [PATCH 1/2] Move canvas dimension rounding to recalibrateSize --- src/containers/paper-canvas.jsx | 32 +++++++++++++++----------------- 1 file changed, 15 insertions(+), 17 deletions(-) diff --git a/src/containers/paper-canvas.jsx b/src/containers/paper-canvas.jsx index 8a6db731..aeb690c1 100644 --- a/src/containers/paper-canvas.jsx +++ b/src/containers/paper-canvas.jsx @@ -224,19 +224,10 @@ class PaperCanvas extends React.Component { // Without the callback, rasters' load function has not been called yet, and they are // positioned incorrectly - paperCanvas.queuedImport = - window.setTimeout(() => { - // Detached - if (!paper.view) return; - // Prevent blurriness caused if the "CSS size" of the element is a float-- - // setting canvas dimensions to floats floors them, but we need to round instead - const elemSize = paper.DomElement.getSize(paper.view.element); - elemSize.width = Math.round(elemSize.width); - elemSize.height = Math.round(elemSize.height); - paper.view.setViewSize(elemSize); - paperCanvas.props.updateViewBounds(paper.view.matrix); - paperCanvas.initializeSvg(item, rotationCenterX, rotationCenterY, viewBox); - }, 0); + paperCanvas.queuedImport = paperCanvas.recalibrateSize(() => { + paperCanvas.props.updateViewBounds(paper.view.matrix); + paperCanvas.initializeSvg(item, rotationCenterX, rotationCenterY, viewBox); + }); } }); } @@ -309,13 +300,20 @@ class PaperCanvas extends React.Component { this.recalibrateSize(); this.props.updateViewBounds(paper.view.matrix); } - recalibrateSize () { + recalibrateSize (callback) { // Sets the size that Paper thinks the canvas is to the size the canvas element actually is. // When these are out of sync, the mouse events in the paint editor don't line up correctly. - window.setTimeout(() => { + return window.setTimeout(() => { if (!paper.view) return; - paper.view.setViewSize(paper.DomElement.getSize(paper.view.element)); - }); + // Prevent blurriness caused if the "CSS size" of the element is a float-- + // setting canvas dimensions to floats floors them, but we need to round instead + const elemSize = paper.DomElement.getSize(paper.view.element); + elemSize.width = Math.round(elemSize.width); + elemSize.height = Math.round(elemSize.height); + paper.view.setViewSize(elemSize); + + if (callback) callback(); + }, 0); } setCanvas (canvas) { this.canvas = canvas; From f76a399b83b53e44fb8db42fd463548c502f762b Mon Sep 17 00:00:00 2001 From: adroitwhiz Date: Mon, 18 May 2020 15:49:52 -0400 Subject: [PATCH 2/2] Add comment on early return if !paper.view --- src/containers/paper-canvas.jsx | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/containers/paper-canvas.jsx b/src/containers/paper-canvas.jsx index aeb690c1..2b2ce63a 100644 --- a/src/containers/paper-canvas.jsx +++ b/src/containers/paper-canvas.jsx @@ -304,6 +304,9 @@ class PaperCanvas extends React.Component { // Sets the size that Paper thinks the canvas is to the size the canvas element actually is. // When these are out of sync, the mouse events in the paint editor don't line up correctly. return window.setTimeout(() => { + // If the component unmounts, the canvas will be removed from the page, detaching paper.view. + // This could also be called before paper.view exists. + // In either case, return early if so without running the callback. if (!paper.view) return; // Prevent blurriness caused if the "CSS size" of the element is a float-- // setting canvas dimensions to floats floors them, but we need to round instead