X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgraphics%2Fwindows%2Fwindow.cpp;h=38e7f730cd5bc6341aaeb00c30ae92fefa4d0374;hb=f575d5573d562e53492e5ddb9021142c7ab0e1a6;hp=c5cdc62070b0e833957489f170637dfa226fd973;hpb=1aca77b93853ee127ac3bbf6886f7f04920542ef;p=libs%2Fgui.git diff --git a/source/graphics/windows/window.cpp b/source/graphics/windows/window.cpp index c5cdc62..38e7f73 100644 --- a/source/graphics/windows/window.cpp +++ b/source/graphics/windows/window.cpp @@ -1,3 +1,4 @@ +#define _WIN32_WINNT 0x0601 #include #include #include @@ -13,15 +14,16 @@ LRESULT CALLBACK wndproc_(HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam) if(msg==WM_CREATE) { CREATESTRUCT *cs = reinterpret_cast(lparam); - SetWindowLong(hwnd, 0, reinterpret_cast(cs->lpCreateParams)); + SetWindowLongPtr(hwnd, 0, reinterpret_cast(cs->lpCreateParams)); } else { - Msp::Graphics::Window *wnd = reinterpret_cast(GetWindowLong(hwnd, 0)); + Msp::Graphics::Window *wnd = reinterpret_cast(GetWindowLongPtr(hwnd, 0)); Msp::Graphics::Window::Event ev; ev.msg = msg; ev.wparam = wparam; ev.lparam = lparam; + ev.extra = GetMessageExtraInfo(); if(wnd && wnd->event(ev)) return 0; } @@ -74,7 +76,8 @@ void Window::platform_init() "mspgui", "Window", style, - CW_USEDEFAULT, CW_USEDEFAULT, + (options.user_position ? options.x : CW_USEDEFAULT), + (options.user_position ? options.y : CW_USEDEFAULT), rect.right-rect.left, rect.bottom-rect.top, 0, 0, @@ -82,6 +85,9 @@ void Window::platform_init() this); if(!priv->window) throw system_error("CreateWindowEx"); + + priv->cursor_in_client_area = false; + priv->cursor_visible = true; } void Window::platform_cleanup() @@ -108,27 +114,49 @@ void Window::platform_reconfigure(bool fullscreen_changed) if(fullscreen_changed) { - hide(); - SetWindowLong(priv->window, GWL_EXSTYLE, exstyle); - SetWindowLong(priv->window, GWL_STYLE, style); - show(); + bool was_visible = visible; + if(was_visible) + hide(); + SetWindowLongPtr(priv->window, GWL_EXSTYLE, exstyle); + SetWindowLongPtr(priv->window, GWL_STYLE, style); + if(was_visible) + show(); } if(options.fullscreen) SetWindowPos(priv->window, 0, 0, 0, rect.right-rect.left, rect.bottom-rect.top, SWP_NOZORDER); + else if(options.user_position) + SetWindowPos(priv->window, 0, options.x, options.y, rect.right-rect.left, rect.bottom-rect.top, SWP_NOZORDER); else SetWindowPos(priv->window, 0, 0, 0, rect.right-rect.left, rect.bottom-rect.top, SWP_NOMOVE|SWP_NOZORDER); } void Window::show_cursor(bool s) { - ShowCursor(s); + priv->cursor_visible = s; + if(priv->cursor_in_client_area && !s) + SetCursor(NULL); } void Window::warp_pointer(int, int) { } +void Window::platform_set_touch_input() +{ + WORD winver = LOWORD(GetVersion); + if(winver<_WIN32_WINNT) + { + touch_input = false; + throw runtime_error("no touch support"); + } + + if(touch_input) + RegisterTouchWindow(priv->window, 3); // TWF_FINETOUCH|TWF_WANTPALM + else + UnregisterTouchWindow(priv->window); +} + void Window::platform_show() { ShowWindow(priv->window, SW_SHOWNORMAL); @@ -145,6 +173,10 @@ bool Window::event(const Event &evnt) { case WM_KEYDOWN: case WM_KEYUP: + case WM_CHAR: + case WM_SYSKEYDOWN: + case WM_SYSKEYUP: + case WM_SYSCHAR: case WM_LBUTTONDOWN: case WM_LBUTTONUP: case WM_MBUTTONDOWN: @@ -153,16 +185,50 @@ bool Window::event(const Event &evnt) case WM_RBUTTONUP: case WM_MOUSEWHEEL: case WM_MOUSEMOVE: + case WM_TOUCH: signal_input_event.emit(evnt); break; case WM_SIZE: options.width = LOWORD(evnt.lparam); options.height = HIWORD(evnt.lparam); + resizing = false; signal_resize.emit(options.width, options.height); break; + case WM_MOVE: + options.x = static_cast(LOWORD(evnt.lparam)); + options.y = static_cast(HIWORD(evnt.lparam)); + moving = false; + signal_move.emit(options.x, options.y); + break; case WM_CLOSE: signal_close.emit(); break; + case WM_PAINT: + { + RECT update_rect; + GetUpdateRect(priv->window, &update_rect, false); + unsigned width = update_rect.right-update_rect.left; + unsigned height = update_rect.bottom-update_rect.top; + signal_expose.emit(update_rect.left, update_rect.top, width, height, evnt); + + PAINTSTRUCT paint; + if(BeginPaint(priv->window, &paint)) + EndPaint(priv->window, &paint); + } + break; + case WM_SETFOCUS: + signal_got_focus.emit(); + break; + case WM_KILLFOCUS: + signal_lost_focus.emit(); + break; + case WM_SETCURSOR: + priv->cursor_in_client_area = (LOWORD(evnt.lparam)==HTCLIENT); + if(priv->cursor_in_client_area && !priv->cursor_visible) + SetCursor(NULL); + else + return false; + break; default: return false; }