Browse Source

Undo eraser

sdf
A.Olokhtonov 5 months ago
parent
commit
5d45eb3255
  1. 6
      README.txt
  2. 13
      client/bvh.js
  3. 13
      client/client_recv.js

6
README.txt

@ -8,14 +8,14 @@ Release:
+ Do not copy memory to wasm, instead use wasm memory to store data in the first place + Do not copy memory to wasm, instead use wasm memory to store data in the first place
+ SIMD for LOD? + SIMD for LOD?
+ Multithreading for LOD + Multithreading for LOD
+ Textured quads (pictures, code already written in older version) + Textured quads (pictures, code already written in older version
+ Resize and move pictures (draw handles) + Resize and move pictures (draw handles)
- Z-prepass fringe bug (also, when do we enable the prepass?) - Z-prepass fringe bug (also, when do we enable the prepass?)
+ Bugs + Bugs
+ GC stalls!!! + GC stalls!!!
+ Stroke previews get connected when drawn without panning on touch devices + Stroke previews get connected when drawn without panning on touch devices
+ Redraw HTML (cursors) on local canvas moves + Redraw HTML (cursors) on local canvas moves
+ New strokes dissapear on the HMH desk + New strokes dissapear on the HMH desk
- Debug - Debug
- Restore ability to limit event range - Restore ability to limit event range
* Listeners/events/multiplayer * Listeners/events/multiplayer
@ -45,8 +45,8 @@ Release:
- Live preview - Live preview
- Alignment (horizontal, vertical, diagonal, etc) - Alignment (horizontal, vertical, diagonal, etc)
+ Undo + Undo
+ Undo for eraser
- Undo for images (add, move, scale) - Undo for images (add, move, scale)
- Undo for eraser
- Redo - Redo
+ Snapping to grid + Snapping to grid
- Snapping to other points? - Snapping to other points?

13
client/bvh.js

@ -176,6 +176,19 @@ function bvh_delete_stroke(state, stroke) {
} }
} }
function bvh_undelete_stroke(state, stroke) {
let node = state.bvh.nodes[stroke.bvh_node];
while (node.parent_index !== null) {
if (node.is_fullnode) {
tv_add2(node.stroke_indices, stroke.index);
break;
}
node = state.bvh.nodes[node.parent_index];
}
}
function bvh_intersect_quad(state, bvh, quad, result_buffer) { function bvh_intersect_quad(state, bvh, quad, result_buffer) {
if (bvh.root === null) { if (bvh.root === null) {
return; return;

13
client/client_recv.js

@ -366,17 +366,24 @@ function handle_event(state, context, event, options = {}) {
break; break;
} else if (other_event.type === EVENT.UNDO) { } else if (other_event.type === EVENT.UNDO) {
// do not undo an undo, we are not Notepad // do not undo an undo, we are not Notepad
} else if (other_event.type === EVENT.IMAGE) {
console.log('TODO: undo image');
} else if (other_event.type === EVENT.IMAGE_MOVE) { } else if (other_event.type === EVENT.IMAGE_MOVE) {
// TODO // TODO
console.log('TODO: undo image scale'); console.log('TODO: undo image move');
break; break;
} else if (other_event.type === EVENT.IMAGE_SCALE) { } else if (other_event.type === EVENT.IMAGE_SCALE) {
// TODO // TODO
console.log('TODO: undo image scale'); console.log('TODO: undo image scale');
break; break;
} else if (other_event.type === EVENT.ERASER) { } else if (other_event.type === EVENT.ERASER) {
// TODO const stroke = state.events[other_event.stroke_id];
console.log('TODO: undo eraser'); stroke.deleted = false;
if (!options.skip_bvh) {
bvh_undelete_stroke(state, stroke);
}
need_draw = true;
other_event.deleted = true;
break; break;
} else { } else {
console.error('cant undo event type', other_event.type); console.error('cant undo event type', other_event.type);

Loading…
Cancel
Save