diff options
author | David Robillard <d@drobilla.net> | 2019-07-22 23:38:37 +0200 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2019-07-23 20:28:56 +0200 |
commit | 8ee970143b2ad1dd4d265bca0aef18aae643d305 (patch) | |
tree | c92268a3bb48aca9c0d3b68adabcf47fdd61f9d4 /pugl/pugl_win.c | |
parent | 614896f49f88f4cefd57d3cf8ce663d984d19231 (diff) | |
download | pugl-8ee970143b2ad1dd4d265bca0aef18aae643d305.tar.gz pugl-8ee970143b2ad1dd4d265bca0aef18aae643d305.tar.bz2 pugl-8ee970143b2ad1dd4d265bca0aef18aae643d305.zip |
Windows: Improve live resize smoothness
Diffstat (limited to 'pugl/pugl_win.c')
-rw-r--r-- | pugl/pugl_win.c | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/pugl/pugl_win.c b/pugl/pugl_win.c index 3f5a293..a75a259 100644 --- a/pugl/pugl_win.c +++ b/pugl/pugl_win.c @@ -661,15 +661,13 @@ handleMessage(PuglView* view, UINT message, WPARAM wParam, LPARAM lParam) switch (message) { case WM_SHOWWINDOW: rect = handleConfigure(view, &event); - InvalidateRect(view->impl->hwnd, &rect, FALSE); - UpdateWindow(view->impl->hwnd); puglPostRedisplay(view); break; case WM_SIZE: - handleConfigure(view, &event); - if (!view->impl->resizing) { - puglPostRedisplay(view); - } + rect = handleConfigure(view, &event); + RedrawWindow(view->impl->hwnd, NULL, NULL, + RDW_INVALIDATE|RDW_ALLCHILDREN|RDW_INTERNALPAINT| + RDW_UPDATENOW); break; case WM_ENTERSIZEMOVE: view->impl->resizing = true; @@ -680,7 +678,8 @@ handleMessage(PuglView* view, UINT message, WPARAM wParam, LPARAM lParam) break; case WM_TIMER: if (wParam == PUGL_RESIZE_TIMER_ID) { - puglPostRedisplay(view); + RedrawWindow(view->impl->hwnd, NULL, NULL, + RDW_INVALIDATE|RDW_ALLCHILDREN|RDW_INTERNALPAINT); } else if (wParam == PUGL_URGENT_TIMER_ID) { FlashWindow(view->impl->hwnd, TRUE); } @@ -688,6 +687,7 @@ handleMessage(PuglView* view, UINT message, WPARAM wParam, LPARAM lParam) case WM_EXITSIZEMOVE: KillTimer(view->impl->hwnd, PUGL_RESIZE_TIMER_ID); view->impl->resizing = false; + puglPostRedisplay(view); break; case WM_GETMINMAXINFO: mmi = (MINMAXINFO*)lParam; @@ -887,7 +887,8 @@ void puglPostRedisplay(PuglView* view) { RedrawWindow(view->impl->hwnd, NULL, NULL, - RDW_INVALIDATE|RDW_INTERNALPAINT); + RDW_INVALIDATE|RDW_ALLCHILDREN|RDW_INTERNALPAINT); + UpdateWindow(view->impl->hwnd); } PuglNativeWindow |