From 841079be0d1e39943ed7cb4433f1fcdf3443bad7 Mon Sep 17 00:00:00 2001 From: "andre@woesten.com" Date: Wed, 5 Nov 2008 20:51:38 +0000 Subject: [PATCH] BUGFIX: TopLevelWindow didn't stay open after closing its modal child --- src/win32cpp/TopLevelWindow.cpp | 33 +++++++++++++++++++++++++++++++-- src/win32cpp/TopLevelWindow.hpp | 1 + 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/src/win32cpp/TopLevelWindow.cpp b/src/win32cpp/TopLevelWindow.cpp index c04e4c5dc..809a66414 100644 --- a/src/win32cpp/TopLevelWindow.cpp +++ b/src/win32cpp/TopLevelWindow.cpp @@ -62,6 +62,7 @@ using namespace win32cpp; , minSize(0, 0) , closed(false) , modalChild(NULL) +, parentWindow(NULL) { } @@ -168,6 +169,26 @@ LRESULT TopLevelWindow::WindowProc(UINT message, WPARAM wParam, LPARAM lPara } return 0; + case WM_DESTROY: + { + // Destroy handler is used together with ShowModal + // According to http://msdn.microsoft.com/en-us/library/ms646291.aspx + // we need to do: + // "A window must be enabled before it can be activated. For example, + // if an application is displaying a modeless dialog box and has disabled + // its main window, the application must enable the main window before + // destroying the dialog box. Otherwise, another window will receive the + // keyboard focus and be activated." + if(this->parentWindow) { + this->parentWindow->Enable(true); + SetForegroundWindow(this->parentWindow->Handle()); + BringWindowToTop(this->parentWindow->Handle()); + + this->parentWindow = NULL; + } + } + break; + case WM_CLOSE: { this->closed = true; @@ -272,7 +293,13 @@ void TopLevelWindow::ShowModal(TopLevelWindow* parent) if (parent) { parent->modalChild = this; + + // Disable keyboard/mouse input on the parent window, + // this also means it gets deactivated (NOT in foreground) parent->Enable(false); + + // Remember the parent window + this->parentWindow = parent; } try @@ -320,8 +347,10 @@ void TopLevelWindow::ShowModal(TopLevelWindow* parent) if (parent) { parent->modalChild = NULL; - parent->Enable(true); - parent->SetFocus(); + } + + if (this->parentWindow) { + this->parentWindow = NULL; } } diff --git a/src/win32cpp/TopLevelWindow.hpp b/src/win32cpp/TopLevelWindow.hpp index baf0b6c1b..b5d7129c2 100644 --- a/src/win32cpp/TopLevelWindow.hpp +++ b/src/win32cpp/TopLevelWindow.hpp @@ -90,6 +90,7 @@ private: // instance data bool closed; Size minSize; TopLevelWindow* modalChild; + Window* parentWindow; }; //////////////////////////////////////////////////////////////////////////////