Browse Source

Better drag/pan

master
A.Olokhtonov 2 years ago
parent
commit
33d1f93d92
  1. 2
      .gitignore
  2. 20
      client/cursor.js
  3. 6
      client/index.js
  4. BIN
      server/data/db.sqlite
  5. 1
      server/storage.js

2
.gitignore vendored

@ -1 +1,3 @@
server/images server/images
doca.txt
data/

20
client/cursor.js

@ -3,6 +3,7 @@ function on_down(e) {
elements.cursor.classList.add('dhide'); elements.cursor.classList.add('dhide');
elements.canvas0.classList.add('moving'); elements.canvas0.classList.add('moving');
storage.state.moving = true; storage.state.moving = true;
storage.state.mousedown = true;
return; return;
} }
@ -11,6 +12,7 @@ function on_down(e) {
} }
if (storage.state.moving) { if (storage.state.moving) {
storage.state.mousedown = true;
return; return;
} }
@ -53,7 +55,7 @@ function on_move(e) {
storage.current_stroke.push(predraw); storage.current_stroke.push(predraw);
fire_event(predraw); fire_event(predraw);
} else if (storage.state.moving) { } else if (storage.state.moving && storage.state.mousedown) {
storage.canvas.offset_x -= e.movementX; storage.canvas.offset_x -= e.movementX;
storage.canvas.offset_y -= e.movementY; storage.canvas.offset_y -= e.movementY;
@ -71,10 +73,14 @@ function on_move(e) {
} }
async function on_up(e) { async function on_up(e) {
if (storage.state.moving && e.button === 1) { if (storage.state.moving && (e.button === 1 || e.button === 0)) {
elements.cursor.classList.remove('dhide'); storage.state.mousedown = false;
elements.canvas0.classList.remove('moving'); if (!storage.state.spacedown) {
storage.state.moving = false; elements.cursor.classList.remove('dhide');
elements.canvas0.classList.remove('moving');
storage.state.moving = false;
return;
}
} }
if (storage.state.drawing && e.button === 0) { if (storage.state.drawing && e.button === 0) {
@ -82,6 +88,7 @@ async function on_up(e) {
const event = stroke_event(); const event = stroke_event();
storage.current_stroke = []; storage.current_stroke = [];
await queue_event(event); await queue_event(event);
return;
} }
} }
@ -90,6 +97,7 @@ function on_keydown(e) {
elements.cursor.classList.add('dhide'); elements.cursor.classList.add('dhide');
elements.canvas0.classList.add('moving'); elements.canvas0.classList.add('moving');
storage.state.moving = true; storage.state.moving = true;
storage.state.spacedown = true;
} }
} }
@ -98,6 +106,7 @@ function on_keyup(e) {
elements.cursor.classList.remove('dhide'); elements.cursor.classList.remove('dhide');
elements.canvas0.classList.remove('moving'); elements.canvas0.classList.remove('moving');
storage.state.moving = false; storage.state.moving = false;
storage.state.spacedown = false;
} }
} }
@ -106,6 +115,7 @@ function on_leave(e) {
elements.cursor.classList.remove('dhide'); elements.cursor.classList.remove('dhide');
elements.canvas0.classList.remove('moving'); elements.canvas0.classList.remove('moving');
storage.state.moving = false; storage.state.moving = false;
storage.state.holding = false;
return; return;
} }
} }

6
client/index.js

@ -31,6 +31,8 @@ const storage = {
'state': { 'state': {
'drawing': false, 'drawing': false,
'moving': false, 'moving': false,
'mousedown': false,
'spacedown': false,
}, },
'predraw': {}, 'predraw': {},
@ -47,8 +49,8 @@ const storage = {
'desk_id': 123, 'desk_id': 123,
'canvas': { 'canvas': {
'width': 2000, 'width': 4096,
'height': 2000, 'height': 4096,
'offset_x': 0, 'offset_x': 0,
'offset_y': 0, 'offset_y': 0,
}, },

BIN
server/data/db.sqlite

Binary file not shown.

1
server/storage.js

@ -109,7 +109,6 @@ export function startup() {
const res5 = db.query('SELECT COUNT(id) as count FROM sessions').get(); const res5 = db.query('SELECT COUNT(id) as count FROM sessions').get();
const res6 = db.query('SELECT COUNT(id) as count FROM images').get(); const res6 = db.query('SELECT COUNT(id) as count FROM images').get();
queries.desks = db.query('SELECT id, sn FROM desks'); queries.desks = db.query('SELECT id, sn FROM desks');
queries.events = db.query('SELECT * FROM events'); queries.events = db.query('SELECT * FROM events');
queries.sessions = db.query('SELECT id, lsn, user_id, desk_id FROM sessions'); queries.sessions = db.query('SELECT id, lsn, user_id, desk_id FROM sessions');

Loading…
Cancel
Save