mirror of
https://github.com/scratchfoundation/scratch-paint.git
synced 2025-01-25 05:39:52 -05:00
Merge pull request #1050 from adroitwhiz/recalibratesize-rounding
Move canvas dimension rounding to recalibrateSize
This commit is contained in:
commit
d7888fd2d1
1 changed files with 18 additions and 17 deletions
|
@ -224,19 +224,10 @@ class PaperCanvas extends React.Component {
|
||||||
|
|
||||||
// Without the callback, rasters' load function has not been called yet, and they are
|
// Without the callback, rasters' load function has not been called yet, and they are
|
||||||
// positioned incorrectly
|
// positioned incorrectly
|
||||||
paperCanvas.queuedImport =
|
paperCanvas.queuedImport = paperCanvas.recalibrateSize(() => {
|
||||||
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.props.updateViewBounds(paper.view.matrix);
|
||||||
paperCanvas.initializeSvg(item, rotationCenterX, rotationCenterY, viewBox);
|
paperCanvas.initializeSvg(item, rotationCenterX, rotationCenterY, viewBox);
|
||||||
}, 0);
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -309,13 +300,23 @@ class PaperCanvas extends React.Component {
|
||||||
this.recalibrateSize();
|
this.recalibrateSize();
|
||||||
this.props.updateViewBounds(paper.view.matrix);
|
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.
|
// 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.
|
// When these are out of sync, the mouse events in the paint editor don't line up correctly.
|
||||||
window.setTimeout(() => {
|
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;
|
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) {
|
setCanvas (canvas) {
|
||||||
this.canvas = canvas;
|
this.canvas = canvas;
|
||||||
|
|
Loading…
Reference in a new issue