mirror of
https://github.com/godotengine/godot.git
synced 2024-11-27 09:16:35 +08:00
Merge pull request #19070 from guilhermefelipecgs/fix_19033
Fix mouse confined and set_borderless_window
This commit is contained in:
commit
0980991e64
@ -1480,7 +1480,7 @@ void OS_OSX::set_cursor_shape(CursorShape p_shape) {
|
||||
if (cursor_shape == p_shape)
|
||||
return;
|
||||
|
||||
if (mouse_mode != MOUSE_MODE_VISIBLE) {
|
||||
if (mouse_mode != MOUSE_MODE_VISIBLE && mouse_mode != MOUSE_MODE_CONFINED) {
|
||||
cursor_shape = p_shape;
|
||||
return;
|
||||
}
|
||||
|
@ -623,9 +623,26 @@ LRESULT OS_Windows::WndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||
case WM_SIZE: {
|
||||
int window_w = LOWORD(lParam);
|
||||
int window_h = HIWORD(lParam);
|
||||
if (window_w > 0 && window_h > 0) {
|
||||
if (window_w > 0 && window_h > 0 && !preserve_window_size) {
|
||||
video_mode.width = window_w;
|
||||
video_mode.height = window_h;
|
||||
} else {
|
||||
preserve_window_size = false;
|
||||
int w = video_mode.width;
|
||||
int h = video_mode.height;
|
||||
|
||||
RECT rect;
|
||||
GetWindowRect(hWnd, &rect);
|
||||
|
||||
if (video_mode.borderless_window == false) {
|
||||
RECT crect;
|
||||
GetClientRect(hWnd, &crect);
|
||||
|
||||
w += (rect.right - rect.left) - (crect.right - crect.left);
|
||||
h += (rect.bottom - rect.top) - (crect.bottom - crect.top);
|
||||
}
|
||||
|
||||
MoveWindow(hWnd, rect.left, rect.top, w, h, TRUE);
|
||||
}
|
||||
if (wParam == SIZE_MAXIMIZED) {
|
||||
maximized = true;
|
||||
@ -1563,6 +1580,15 @@ void OS_Windows::set_window_size(const Size2 p_size) {
|
||||
}
|
||||
|
||||
MoveWindow(hWnd, rect.left, rect.top, w, h, TRUE);
|
||||
|
||||
// Don't let the mouse leave the window when resizing to a smaller resolution
|
||||
if (mouse_mode == MOUSE_MODE_CONFINED) {
|
||||
RECT rect;
|
||||
GetClientRect(hWnd, &rect);
|
||||
ClientToScreen(hWnd, (POINT *)&rect.left);
|
||||
ClientToScreen(hWnd, (POINT *)&rect.right);
|
||||
ClipCursor(&rect);
|
||||
}
|
||||
}
|
||||
void OS_Windows::set_window_fullscreen(bool p_enabled) {
|
||||
|
||||
@ -1769,6 +1795,7 @@ void OS_Windows::set_borderless_window(bool p_borderless) {
|
||||
|
||||
video_mode.borderless_window = p_borderless;
|
||||
|
||||
preserve_window_size = true;
|
||||
_update_window_style();
|
||||
}
|
||||
|
||||
@ -1787,7 +1814,7 @@ void OS_Windows::_update_window_style(bool repaint) {
|
||||
}
|
||||
}
|
||||
|
||||
SetWindowPos(hWnd, video_mode.always_on_top ? HWND_TOPMOST : HWND_NOTOPMOST, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE);
|
||||
SetWindowPos(hWnd, video_mode.always_on_top ? HWND_TOPMOST : HWND_NOTOPMOST, 0, 0, 0, 0, SWP_FRAMECHANGED | SWP_NOMOVE | SWP_NOSIZE);
|
||||
|
||||
if (repaint) {
|
||||
RECT rect;
|
||||
@ -1998,7 +2025,7 @@ void OS_Windows::set_cursor_shape(CursorShape p_shape) {
|
||||
if (cursor_shape == p_shape)
|
||||
return;
|
||||
|
||||
if (mouse_mode != MOUSE_MODE_VISIBLE) {
|
||||
if (mouse_mode != MOUSE_MODE_VISIBLE && mouse_mode != MOUSE_MODE_CONFINED) {
|
||||
cursor_shape = p_shape;
|
||||
return;
|
||||
}
|
||||
|
@ -105,6 +105,7 @@ class OS_Windows : public OS {
|
||||
|
||||
Size2 window_rect;
|
||||
VideoMode video_mode;
|
||||
bool preserve_window_size = false;
|
||||
|
||||
MainLoop *main_loop;
|
||||
|
||||
|
@ -2407,7 +2407,7 @@ void OS_X11::set_cursor_shape(CursorShape p_shape) {
|
||||
|
||||
if (p_shape == current_cursor)
|
||||
return;
|
||||
if (mouse_mode == MOUSE_MODE_VISIBLE) {
|
||||
if (mouse_mode == MOUSE_MODE_VISIBLE && mouse_mode != MOUSE_MODE_CONFINED) {
|
||||
if (cursors[p_shape] != None)
|
||||
XDefineCursor(x11_display, x11_window, cursors[p_shape]);
|
||||
else if (cursors[CURSOR_ARROW] != None)
|
||||
|
Loading…
Reference in New Issue
Block a user