From 68ccd1e61120892015a3852901a6a7527a950198 Mon Sep 17 00:00:00 2001 From: Rom Walton Date: Mon, 23 Jan 2012 19:30:51 +0000 Subject: [PATCH] - MGR: Tweak the z-order of BOINC Manager owned windows a little bit. Image a case where BOINC Manager and the BOINC Manager event log live side-by-side or only slightly overlapped, and the user wants to use a full screen/maximized window. If the bring the BOINC manager window back into focus while that app is still running make sure the event log comes forward as well. The event log should appear behind the main window in the case they are overlapped. clientgui/ BOINCGUIApp.cpp, .h svn path=/trunk/boinc/; revision=25129 --- checkin_notes | 13 +++++++++++++ clientgui/BOINCGUIApp.cpp | 31 +++++++++++++++++++++++-------- clientgui/BOINCGUIApp.h | 1 + 3 files changed, 37 insertions(+), 8 deletions(-) diff --git a/checkin_notes b/checkin_notes index 23d97aca7f..fbe1b79b3d 100644 --- a/checkin_notes +++ b/checkin_notes @@ -890,3 +890,16 @@ David 22 Jan 2012 client/ cpu_sched.cpp + +Rom 23 Jan 2012 + - MGR: Tweak the z-order of BOINC Manager owned windows a little bit. + Image a case where BOINC Manager and the BOINC Manager event log + live side-by-side or only slightly overlapped, and the user wants + to use a full screen/maximized window. If the bring the BOINC + manager window back into focus while that app is still running + make sure the event log comes forward as well. The event log + should appear behind the main window in the case they are + overlapped. + + clientgui/ + BOINCGUIApp.cpp, .h diff --git a/clientgui/BOINCGUIApp.cpp b/clientgui/BOINCGUIApp.cpp index e5d0bb14e0..1f8c739379 100644 --- a/clientgui/BOINCGUIApp.cpp +++ b/clientgui/BOINCGUIApp.cpp @@ -60,6 +60,7 @@ IMPLEMENT_APP(CBOINCGUIApp) IMPLEMENT_DYNAMIC_CLASS(CBOINCGUIApp, wxApp) BEGIN_EVENT_TABLE (CBOINCGUIApp, wxApp) + EVT_ACTIVATE_APP(CBOINCGUIApp::OnActivateApp) EVT_RPC_FINISHED(CBOINCGUIApp::OnRPCFinished) END_EVENT_TABLE () @@ -787,6 +788,17 @@ int CBOINCGUIApp::IdleTrackerDetach() { } +void CBOINCGUIApp::OnActivateApp(wxActivateEvent& event) { + if (event.GetActive()) { + if (m_pEventLog && !m_pEventLog->IsIconized()) { + m_pEventLog->Raise(); + } + m_pFrame->Raise(); + } + event.Skip(); +} + + void CBOINCGUIApp::OnRPCFinished( CRPCFinishedEvent& event ) { CMainDocument* pDoc = wxGetApp().GetDocument(); @@ -839,7 +851,7 @@ int CBOINCGUIApp::StartBOINCDefaultScreensaverTest() { // Display the Event Log, it is a modeless dialog not owned by any // other UI element. void CBOINCGUIApp::DisplayEventLog(bool bShowWindow) { - if (m_pEventLog ) { + if (m_pEventLog) { if (bShowWindow) { if (m_pEventLog->IsIconized()) { m_pEventLog->Iconize(false); @@ -991,17 +1003,20 @@ bool CBOINCGUIApp::SetActiveGUI(int iGUISelection, bool bShowWindow) { } // Show the new frame if needed - if (m_pFrame && !m_pFrame->IsShown() && bShowWindow) { - m_pFrame->Show(); - m_pFrame->Raise(); + if (m_pFrame && bShowWindow) { + if (m_pEventLog) { + m_pEventLog->Show(); + m_pEventLog->Raise(); #ifdef __WXMSW__ - ::SetForegroundWindow((HWND)m_pFrame->GetHWND()); + ::SetForegroundWindow((HWND)m_pEventLog->GetHWND()); #endif - } + } - // Raise the frame to the top of the Z order if needed - if (m_pFrame && m_pFrame->IsShown() && bShowWindow) { + if (!m_pFrame->IsShown()) { + m_pFrame->Show(); + } m_pFrame->Raise(); + #ifdef __WXMSW__ ::SetForegroundWindow((HWND)m_pFrame->GetHWND()); #endif diff --git a/clientgui/BOINCGUIApp.h b/clientgui/BOINCGUIApp.h index c4e8ace87f..e0cd490b6e 100644 --- a/clientgui/BOINCGUIApp.h +++ b/clientgui/BOINCGUIApp.h @@ -168,6 +168,7 @@ public: bool SetActiveGUI(int iGUISelection, bool bShowWindow = true); + void OnActivateApp( wxActivateEvent& event ); void OnRPCFinished( CRPCFinishedEvent& event ); int ConfirmExit();