From 2d543af17307ef80222b901236d0fbdd74bb3fd5 Mon Sep 17 00:00:00 2001 From: Relintai Date: Thu, 1 Sep 2022 00:40:18 +0200 Subject: [PATCH] Fix PaintWindow with mouse emulation from touch. --- modules/paint/paint_window.cpp | 41 ++++++++++++++++++++++++++++++++++ modules/paint/paint_window.h | 1 + 2 files changed, 42 insertions(+) diff --git a/modules/paint/paint_window.cpp b/modules/paint/paint_window.cpp index 8aa74b9f5..4d481d757 100644 --- a/modules/paint/paint_window.cpp +++ b/modules/paint/paint_window.cpp @@ -250,6 +250,33 @@ void PaintWindow::_input(const Ref &event) { Ref iemb = event; if (iemb.is_valid()) { + if (iemb->get_device() == InputEvent::DEVICE_ID_TOUCH_MOUSE) { + Vector2 mouse_position = paint_canvas->get_local_mouse_position(); + Rect2 rect = Rect2(Vector2(0, 0), paint_canvas->get_size()); + bool has_point = rect.has_point(mouse_position); + + if (has_point && !paint_canvas->mouse_in_region) { + paint_canvas->mouse_in_region = true; + _on_PaintCanvasContainer_mouse_entered(); + paint_canvas->_on_mouse_entered(); + //_process(0.0000001); + + int grid_size = paint_canvas->get_pixel_size(); + mouse_position = get_global_mouse_position(); + canvas_position = paint_canvas->get_global_position(); + canvas_mouse_position = Vector2(mouse_position.x - canvas_position.x, mouse_position.y - canvas_position.y); + cell_mouse_position = Vector2(floor(canvas_mouse_position.x / grid_size), floor(canvas_mouse_position.y / grid_size)); + cell_color = paint_canvas->get_pixel(cell_mouse_position.x, cell_mouse_position.y); + last_mouse_position = mouse_position; + last_canvas_position = canvas_position; + last_canvas_mouse_position = canvas_mouse_position; + last_cell_mouse_position = cell_mouse_position; + last_cell_color = cell_color; + + _last_mouse_pos_canvas_area = get_global_mouse_position(); //paint_canvas_container_node.get_local_mouse_position() + } + } + if (brush_mode == Tools::CUT) { if (iemb->get_button_index() == BUTTON_LEFT && !iemb->is_pressed()) { commit_action(); @@ -306,6 +333,19 @@ void PaintWindow::_input(const Ref &event) { break; } } + + if (iemb->get_device() == InputEvent::DEVICE_ID_TOUCH_MOUSE) { + Vector2 mouse_position = paint_canvas->get_local_mouse_position(); + Rect2 rect = Rect2(Vector2(0, 0), paint_canvas->get_size()); + bool has_point = rect.has_point(mouse_position); + + if (!has_point && paint_canvas->mouse_in_region) { + paint_canvas->mouse_in_region = false; + _on_PaintCanvasContainer_mouse_exited(); + paint_canvas->_on_mouse_exited(); + //_process(0.0000001); + } + } } } void PaintWindow::_process(float delta) { @@ -1234,6 +1274,7 @@ PaintWindow::PaintWindow() { mouse_in_region = false; mouse_on_top = false; + mouse_from_touch = false; _picked_color = false; diff --git a/modules/paint/paint_window.h b/modules/paint/paint_window.h index 3d602c7db..016d59f5c 100644 --- a/modules/paint/paint_window.h +++ b/modules/paint/paint_window.h @@ -249,6 +249,7 @@ public: bool mouse_in_region; bool mouse_on_top; + bool mouse_from_touch; Vector2 _middle_mouse_pressed_pos; Vector2 _middle_mouse_pressed_start_pos;