From fbd62e61e3fdbea11c21015bdd75157475a331aa Mon Sep 17 00:00:00 2001 From: Zacrain <43988454+Zacrain@users.noreply.github.com> Date: Fri, 20 Sep 2024 18:50:22 +0200 Subject: [PATCH] Disable stroke while panning or zooming (#302) * Disable stroke while panning or zooming - End stroking of brush tool when zooming * Rename symbols --- .gitignore | 3 +++ lorien/InfiniteCanvas/InfiniteCanvas.gd | 9 +++++++-- lorien/InfiniteCanvas/PanZoomCamera.gd | 8 ++++++++ lorien/InfiniteCanvas/Tools/BrushTool.gd | 4 +++- lorien/InfiniteCanvas/Tools/CanvasTool.gd | 16 ++++++++++++++++ lorien/InfiniteCanvas/Tools/CircleTool.gd | 2 +- lorien/InfiniteCanvas/Tools/EraserTool.gd | 2 +- lorien/InfiniteCanvas/Tools/LineTool.gd | 2 +- lorien/InfiniteCanvas/Tools/RectangleTool.gd | 2 +- lorien/InfiniteCanvas/Tools/SelectionTool.gd | 2 +- 10 files changed, 42 insertions(+), 8 deletions(-) diff --git a/.gitignore b/.gitignore index 6201c00f..9df13c22 100644 --- a/.gitignore +++ b/.gitignore @@ -5,3 +5,6 @@ # Mono-specific ignores .mono/ data_*/ + +# Visual Studio Code-specific ignores +.vscode/ diff --git a/lorien/InfiniteCanvas/InfiniteCanvas.gd b/lorien/InfiniteCanvas/InfiniteCanvas.gd index 39175af4..035dc1ff 100644 --- a/lorien/InfiniteCanvas/InfiniteCanvas.gd +++ b/lorien/InfiniteCanvas/InfiniteCanvas.gd @@ -52,8 +52,13 @@ func _ready() -> void: for child in $SubViewport.get_children(): if child is BaseCursor: - _camera.zoom_changed.connect(Callable(child, "_on_zoom_changed")) - _camera.position_changed.connect(Callable(child, "_on_canvas_position_changed")) + _camera.zoom_changed.connect(child._on_zoom_changed) + _camera.position_changed.connect(child._on_canvas_position_changed) + + for child in get_children(): + if child is CanvasTool: + _camera.panning_toggled.connect(child._on_panning_toggled) + _camera.zooming_toggled.connect(child._on_zooming_toggled) _camera.zoom_changed.connect(_on_zoom_changed) _camera.position_changed.connect(_on_camera_moved) diff --git a/lorien/InfiniteCanvas/PanZoomCamera.gd b/lorien/InfiniteCanvas/PanZoomCamera.gd index 06387bf0..15afcf98 100644 --- a/lorien/InfiniteCanvas/PanZoomCamera.gd +++ b/lorien/InfiniteCanvas/PanZoomCamera.gd @@ -1,7 +1,9 @@ extends Camera2D # ------------------------------------------------------------------------------------------------- +signal zooming_toggled(value: bool) signal zoom_changed(value: float) +signal panning_toggled(value: bool) signal position_changed(value: Vector2) # ------------------------------------------------------------------------------------------------- @@ -39,8 +41,10 @@ func tool_event(event: InputEvent) -> void: if event is InputEventKey: if Utils.is_action_pressed("canvas_pan_key", event): _pan_active = true + panning_toggled.emit(true) if Utils.is_action_released("canvas_pan_key", event): _pan_active = false + panning_toggled.emit(false) if event is InputEventMouseButton: # Scroll wheel up/down to zoom @@ -55,10 +59,14 @@ func tool_event(event: InputEvent) -> void: if event.button_index == MOUSE_BUTTON_MIDDLE: if !event.ctrl_pressed: _pan_active = event.is_pressed() + panning_toggled.emit(_pan_active) _zoom_active = false + zooming_toggled.emit(false) else: _zoom_active = event.is_pressed() + zooming_toggled.emit(_zoom_active) _pan_active = false + panning_toggled.emit(false) _start_mouse_pos = get_local_mouse_position() elif event is InputEventMouseMotion: diff --git a/lorien/InfiniteCanvas/Tools/BrushTool.gd b/lorien/InfiniteCanvas/Tools/BrushTool.gd index ce052a1d..60c1dfd7 100644 --- a/lorien/InfiniteCanvas/Tools/BrushTool.gd +++ b/lorien/InfiniteCanvas/Tools/BrushTool.gd @@ -22,8 +22,10 @@ func tool_event(event: InputEvent) -> void: _current_pressure = event.pressure if performing_stroke: _cursor.set_pressure(event.pressure) + if zooming_detected && performing_stroke: + end_stroke() - elif event is InputEventMouseButton: + elif event is InputEventMouseButton && !disable_stroke: if event.button_index == MOUSE_BUTTON_LEFT: if event.pressed: start_stroke() diff --git a/lorien/InfiniteCanvas/Tools/CanvasTool.gd b/lorien/InfiniteCanvas/Tools/CanvasTool.gd index 7768ef05..b0c01e35 100644 --- a/lorien/InfiniteCanvas/Tools/CanvasTool.gd +++ b/lorien/InfiniteCanvas/Tools/CanvasTool.gd @@ -13,6 +13,9 @@ var _cursor: BaseCursor var _canvas: InfiniteCanvas var enabled := false: get = get_enabled, set = set_enabled var performing_stroke := false +var disable_stroke := false +var panning_detected := false +var zooming_detected := false # ------------------------------------------------------------------------------------------------- func _ready() -> void: @@ -32,6 +35,16 @@ func _on_brush_color_changed(color: Color) -> void: func _on_brush_size_changed(size: int) -> void: _cursor.change_size(size) +# ------------------------------------------------------------------------------------------------- +func _on_panning_toggled(panning_enabled: bool) -> void: + panning_detected = panning_enabled + _eval_disable_stroke() + +# ------------------------------------------------------------------------------------------------- +func _on_zooming_toggled(zooming_enabled: bool) -> void: + zooming_detected = zooming_enabled + _eval_disable_stroke() + # ------------------------------------------------------------------------------------------------- func get_cursor() -> BaseCursor: return _cursor @@ -89,6 +102,9 @@ func end_stroke() -> void: _canvas.end_stroke() performing_stroke = false +func _eval_disable_stroke() -> void: + disable_stroke = panning_detected || zooming_detected + # TODO(gd4): probably don't need this anymore # ------------------------------------------------------------------------------------------------- #func xform_vector2(v: Vector2) -> Vector2: diff --git a/lorien/InfiniteCanvas/Tools/CircleTool.gd b/lorien/InfiniteCanvas/Tools/CircleTool.gd index 472c17fe..994a36a0 100644 --- a/lorien/InfiniteCanvas/Tools/CircleTool.gd +++ b/lorien/InfiniteCanvas/Tools/CircleTool.gd @@ -35,7 +35,7 @@ func tool_event(event: InputEvent) -> void: _make_ellipse(PRESSURE, STEP_IN_MOTION, should_draw_circle) # Start + End - elif event is InputEventMouseButton: + elif event is InputEventMouseButton && !disable_stroke: if event.button_index == MOUSE_BUTTON_LEFT: if event.pressed: start_stroke() diff --git a/lorien/InfiniteCanvas/Tools/EraserTool.gd b/lorien/InfiniteCanvas/Tools/EraserTool.gd index e9cbed3c..9e9f1383 100644 --- a/lorien/InfiniteCanvas/Tools/EraserTool.gd +++ b/lorien/InfiniteCanvas/Tools/EraserTool.gd @@ -14,7 +14,7 @@ var _bounding_box_cache := {} # BrushStroke -> Rect2 func tool_event(event: InputEvent) -> void: if event is InputEventMouseMotion: _last_mouse_position = _cursor.global_position - if event is InputEventMouseButton: + if event is InputEventMouseButton && !disable_stroke: if event.button_index == MOUSE_BUTTON_LEFT: if event.pressed: if _bounding_box_cache.is_empty(): diff --git a/lorien/InfiniteCanvas/Tools/LineTool.gd b/lorien/InfiniteCanvas/Tools/LineTool.gd index 3b6d98d4..4ff9506e 100644 --- a/lorien/InfiniteCanvas/Tools/LineTool.gd +++ b/lorien/InfiniteCanvas/Tools/LineTool.gd @@ -30,7 +30,7 @@ func tool_event(event: InputEvent) -> void: _tail = _add_point_at_mouse_pos(0.5) # Start + End - elif event is InputEventMouseButton: + elif event is InputEventMouseButton && !disable_stroke: if event.button_index == MOUSE_BUTTON_LEFT: if event.pressed: start_stroke() diff --git a/lorien/InfiniteCanvas/Tools/RectangleTool.gd b/lorien/InfiniteCanvas/Tools/RectangleTool.gd index 34790014..505a5cbe 100644 --- a/lorien/InfiniteCanvas/Tools/RectangleTool.gd +++ b/lorien/InfiniteCanvas/Tools/RectangleTool.gd @@ -19,7 +19,7 @@ func tool_event(event: InputEvent) -> void: _make_rectangle(PRESSURE) # Start + End - elif event is InputEventMouseButton: + elif event is InputEventMouseButton && !disable_stroke: if event.button_index == MOUSE_BUTTON_LEFT: if event.pressed: start_stroke() diff --git a/lorien/InfiniteCanvas/Tools/SelectionTool.gd b/lorien/InfiniteCanvas/Tools/SelectionTool.gd index c1cdaaf7..1ae69d1e 100644 --- a/lorien/InfiniteCanvas/Tools/SelectionTool.gd +++ b/lorien/InfiniteCanvas/Tools/SelectionTool.gd @@ -57,7 +57,7 @@ func tool_event(event: InputEvent) -> void: _cursor.mode = SelectionCursor.Mode.MOVE _paste_strokes(strokes) - if event is InputEventMouseButton: + if event is InputEventMouseButton && !disable_stroke: if event.button_index == MOUSE_BUTTON_LEFT: # LMB down - decide if we should select/multiselect or move the selection if event.pressed: