diff --git a/src/osx/cocoa/utils.mm b/src/osx/cocoa/utils.mm index f8926e800b..8d32b3a5c7 100644 --- a/src/osx/cocoa/utils.mm +++ b/src/osx/cocoa/utils.mm @@ -127,6 +127,49 @@ void wxBell() return NO; } +- (void)applicationDidBecomeActive:(NSNotification *)notification +{ + wxUnusedVar(notification); + + for ( wxWindowList::const_iterator i = wxTopLevelWindows.begin(), + end = wxTopLevelWindows.end(); + i != end; + ++i ) + { + wxTopLevelWindow * const win = static_cast(*i); + wxNonOwnedWindowImpl* winimpl = win ? win->GetNonOwnedPeer() : NULL; + WXWindow nswindow = win ? win->GetWXWindow() : nil; + + if ( nswindow && [nswindow hidesOnDeactivate] == NO && winimpl) + winimpl->RestoreWindowLevel(); + } + if ( wxTheApp ) + wxTheApp->SetActive( true , NULL ) ; +} + +- (void)applicationWillResignActive:(NSNotification *)notification +{ + wxUnusedVar(notification); + for ( wxWindowList::const_iterator i = wxTopLevelWindows.begin(), + end = wxTopLevelWindows.end(); + i != end; + ++i ) + { + wxTopLevelWindow * const win = static_cast(*i); + WXWindow nswindow = win ? win->GetWXWindow() : nil; + + if ( nswindow && [nswindow level] == kCGFloatingWindowLevel && [nswindow hidesOnDeactivate] == NO ) + [nswindow setLevel:kCGNormalWindowLevel]; + } +} + +- (void)applicationDidResignActive:(NSNotification *)notification +{ + wxUnusedVar(notification); + if ( wxTheApp ) + wxTheApp->SetActive( false , NULL ) ; +} + @end /*