Merge pull request #95665 from Hilderin/fix-drag-drop-between-window
Fix drag&drop between window on Windows
This commit is contained in:
commit
100fbb51ab
|
@ -4951,6 +4951,16 @@ LRESULT DisplayServerWindows::WndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARA
|
|||
Input::get_singleton()->parse_input_event(mbd);
|
||||
}
|
||||
|
||||
// Propagate the button up event to the window on which the button down
|
||||
// event was triggered. This is needed for drag & drop to work between windows,
|
||||
// because the engine expects events to keep being processed
|
||||
// on the same window dragging started.
|
||||
if (mb->is_pressed()) {
|
||||
last_mouse_button_down_window = window_id;
|
||||
} else if (last_mouse_button_down_window != INVALID_WINDOW_ID) {
|
||||
mb->set_window_id(last_mouse_button_down_window);
|
||||
last_mouse_button_down_window = INVALID_WINDOW_ID;
|
||||
}
|
||||
} break;
|
||||
|
||||
case WM_WINDOWPOSCHANGED: {
|
||||
|
|
|
@ -537,7 +537,7 @@ class DisplayServerWindows : public DisplayServer {
|
|||
RBMap<WindowID, WindowData> windows;
|
||||
|
||||
WindowID last_focused_window = INVALID_WINDOW_ID;
|
||||
|
||||
WindowID last_mouse_button_down_window = INVALID_WINDOW_ID;
|
||||
HCURSOR hCursor;
|
||||
|
||||
WNDPROC user_proc = nullptr;
|
||||
|
|
Loading…
Reference in New Issue