make canvas dragging a bit snappier by calculating the drag delta ourselves
I'm really thankful for `listen` here. it makes this sort of logic super easy without having to add class fields.
This commit is contained in:
parent
bfbde0dee3
commit
740a62447e
2 changed files with 8 additions and 6 deletions
|
@ -394,12 +394,19 @@ class CanvasRenderer extends HTMLElement {
|
|||
async #panningBehaviour() {
|
||||
while (true) {
|
||||
let mouseDown = await listen([this, "mousedown"]);
|
||||
|
||||
let startingPanX = this.viewport.panX;
|
||||
let startingPanY = this.viewport.panY;
|
||||
|
||||
if (mouseDown.button == 1 || mouseDown.button == 2) {
|
||||
mouseDown.preventDefault();
|
||||
while (true) {
|
||||
let event = await listen([window, "mousemove"], [window, "mouseup"]);
|
||||
if (event.type == "mousemove") {
|
||||
this.viewport.panAround(event.movementX, event.movementY);
|
||||
let deltaX = mouseDown.clientX - event.clientX;
|
||||
let deltaY = mouseDown.clientY - event.clientY;
|
||||
this.viewport.panX = startingPanX + deltaX / this.viewport.zoom;
|
||||
this.viewport.panY = startingPanY + deltaY / this.viewport.zoom;
|
||||
this.sendViewportUpdate();
|
||||
} else if (event.type == "mouseup" && event.button == mouseDown.button) {
|
||||
this.dispatchEvent(new Event(".viewportUpdateEnd"));
|
||||
|
|
|
@ -9,11 +9,6 @@ export class Viewport {
|
|||
return Math.pow(2, this.zoomLevel * 0.25);
|
||||
}
|
||||
|
||||
panAround(x, y) {
|
||||
this.panX -= x / this.zoom;
|
||||
this.panY -= y / this.zoom;
|
||||
}
|
||||
|
||||
zoomIn(delta) {
|
||||
this.zoomLevel += delta;
|
||||
this.zoomLevel = Math.max(-16, Math.min(20, this.zoomLevel));
|
||||
|
|
Loading…
Reference in a new issue