Proposed wxMac MDI interface (in limbo)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@21128 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
David Elliott
2003-06-13 20:29:48 +00:00
parent 31bb77da45
commit 70024cfb08
3 changed files with 213 additions and 30 deletions

View File

@@ -54,6 +54,10 @@ public:
long style = wxDEFAULT_FRAME_STYLE | wxVSCROLL | wxHSCROLL,
const wxString& name = wxFrameNameStr);
// Mac OS activate event
virtual void MacActivate(long timestamp, bool activating);
// wxWindows activate event
void OnActivate(wxActivateEvent& event);
void OnSysColourChanged(wxSysColourChangedEvent& event);
@@ -119,6 +123,9 @@ public:
long style = wxDEFAULT_FRAME_STYLE,
const wxString& name = wxFrameNameStr);
// Mac OS activate event
virtual void MacActivate(long timestamp, bool activating);
// Set menu bar
void SetMenuBar(wxMenuBar *menu_bar);

View File

@@ -16,8 +16,10 @@
#include "wx/mdi.h"
#include "wx/menu.h"
#include "wx/settings.h"
#include "wx/log.h"
#include "wx/mac/private.h"
#include "wx/mac/uma.h"
extern wxWindowList wxModelessWindows;
@@ -92,7 +94,7 @@ bool wxMDIParentFrame::Create(wxWindow *parent,
m_windowMenu->Append(IDM_WINDOWNEXT, wxT("&Next"));
}
wxFrame::Create( parent , id , title , wxPoint( 2000 , 2000 ) , size , style , name ) ;
wxFrame::Create( parent , id , title , pos , size , style , name ) ;
m_parentFrameActive = TRUE;
OnCreateClient();
@@ -127,22 +129,55 @@ void wxMDIParentFrame::SetMenuBar(wxMenuBar *menu_bar)
wxFrame::SetMenuBar( menu_bar ) ;
}
void wxMDIParentFrame::OnActivate(wxActivateEvent& event)
void wxMDIParentFrame::MacActivate(long timestamp, bool activating)
{
if ( m_currentChild && event.GetActive() )
wxLogDebug("MDI PARENT=%p MacActivate(0x%08lx,%s)",this,timestamp,activating?"ACTIV":"deact");
if(activating)
{
wxActivateEvent event(wxEVT_ACTIVATE, TRUE, m_currentChild->GetId());
event.SetEventObject( m_currentChild );
m_currentChild->GetEventHandler()->ProcessEvent(event) ;
if(s_macDeactivateWindow && s_macDeactivateWindow->GetParent()==this)
{
wxLogDebug("child had been scheduled for deactivation, rehighlighting");
UMAHighlightAndActivateWindow((WindowRef)s_macDeactivateWindow->MacGetWindowRef(), true);
wxLogDebug("done highliting child");
s_macDeactivateWindow = NULL;
}
else if ( event.GetActive() )
else if(s_macDeactivateWindow == this)
{
if ( m_frameMenuBar != NULL )
wxLogDebug("Avoided deactivation/activation of this=%p", this);
s_macDeactivateWindow = NULL;
}
else // window to deactivate is NULL or is not us or one of our kids
{
m_frameMenuBar->MacInstallMenuBar() ;
// activate kid instead
if(m_currentChild)
m_currentChild->MacActivate(timestamp,activating);
else
wxFrame::MacActivate(timestamp,activating);
}
}
else
{
// We were scheduled for deactivation, and now we do it.
if(s_macDeactivateWindow==this)
{
s_macDeactivateWindow = NULL;
if(m_currentChild)
m_currentChild->MacActivate(timestamp,activating);
wxFrame::MacActivate(timestamp,activating);
}
else // schedule ourselves for deactivation
{
if(s_macDeactivateWindow)
wxLogDebug("window=%p SHOULD have been deactivated, oh well!",s_macDeactivateWindow);
wxLogDebug("Scheduling delayed MDI Parent deactivation");
s_macDeactivateWindow = this;
}
}
}
}
void wxMDIParentFrame::OnActivate(wxActivateEvent& event)
{
event.Skip();
}
// Returns the active MDI child window
@@ -232,6 +267,10 @@ bool wxMDIChildFrame::Create(wxMDIParentFrame *parent,
wxMDIChildFrame::~wxMDIChildFrame()
{
wxMDIParentFrame *mdiparent = wxDynamicCast(m_parent, wxMDIParentFrame);
wxASSERT(mdiparent);
if(mdiparent->m_currentChild == this)
mdiparent->m_currentChild = NULL;
DestroyChildren();
// already delete by DestroyChildren()
m_frameToolBar = NULL;
@@ -243,6 +282,55 @@ void wxMDIChildFrame::SetMenuBar(wxMenuBar *menu_bar)
return wxFrame::SetMenuBar( menu_bar ) ;
}
void wxMDIChildFrame::MacActivate(long timestamp, bool activating)
{
wxLogDebug("MDI child=%p MacActivate(0x%08lx,%s)",this,timestamp,activating?"ACTIV":"deact");
wxMDIParentFrame *mdiparent = wxDynamicCast(m_parent, wxMDIParentFrame);
wxASSERT(mdiparent);
if(activating)
{
if(s_macDeactivateWindow == m_parent)
{
wxLogDebug("parent had been scheduled for deactivation, rehighlighting");
UMAHighlightAndActivateWindow((WindowRef)s_macDeactivateWindow->MacGetWindowRef(), true);
wxLogDebug("done highliting parent");
s_macDeactivateWindow = NULL;
}
else if((mdiparent->m_currentChild==this) || !s_macDeactivateWindow)
mdiparent->wxFrame::MacActivate(timestamp,activating);
if(mdiparent->m_currentChild && mdiparent->m_currentChild!=this)
mdiparent->m_currentChild->wxFrame::MacActivate(timestamp,false);
mdiparent->m_currentChild = this;
if(s_macDeactivateWindow==this)
{
wxLogDebug("Avoided deactivation/activation of this=%p",this);
s_macDeactivateWindow=NULL;
}
else
wxFrame::MacActivate(timestamp, activating);
}
else
{
// We were scheduled for deactivation, and now we do it.
if(s_macDeactivateWindow==this)
{
s_macDeactivateWindow = NULL;
wxFrame::MacActivate(timestamp,activating);
if(mdiparent->m_currentChild==this)
mdiparent->wxFrame::MacActivate(timestamp,activating);
}
else // schedule ourselves for deactivation
{
if(s_macDeactivateWindow)
wxLogDebug("window=%p SHOULD have been deactivated, oh well!",s_macDeactivateWindow);
wxLogDebug("Scheduling delayed deactivation");
s_macDeactivateWindow = this;
}
}
}
// MDI operations
void wxMDIChildFrame::Maximize()
{

View File

@@ -16,8 +16,10 @@
#include "wx/mdi.h"
#include "wx/menu.h"
#include "wx/settings.h"
#include "wx/log.h"
#include "wx/mac/private.h"
#include "wx/mac/uma.h"
extern wxWindowList wxModelessWindows;
@@ -92,7 +94,7 @@ bool wxMDIParentFrame::Create(wxWindow *parent,
m_windowMenu->Append(IDM_WINDOWNEXT, wxT("&Next"));
}
wxFrame::Create( parent , id , title , wxPoint( 2000 , 2000 ) , size , style , name ) ;
wxFrame::Create( parent , id , title , pos , size , style , name ) ;
m_parentFrameActive = TRUE;
OnCreateClient();
@@ -127,22 +129,55 @@ void wxMDIParentFrame::SetMenuBar(wxMenuBar *menu_bar)
wxFrame::SetMenuBar( menu_bar ) ;
}
void wxMDIParentFrame::OnActivate(wxActivateEvent& event)
void wxMDIParentFrame::MacActivate(long timestamp, bool activating)
{
if ( m_currentChild && event.GetActive() )
wxLogDebug("MDI PARENT=%p MacActivate(0x%08lx,%s)",this,timestamp,activating?"ACTIV":"deact");
if(activating)
{
wxActivateEvent event(wxEVT_ACTIVATE, TRUE, m_currentChild->GetId());
event.SetEventObject( m_currentChild );
m_currentChild->GetEventHandler()->ProcessEvent(event) ;
if(s_macDeactivateWindow && s_macDeactivateWindow->GetParent()==this)
{
wxLogDebug("child had been scheduled for deactivation, rehighlighting");
UMAHighlightAndActivateWindow((WindowRef)s_macDeactivateWindow->MacGetWindowRef(), true);
wxLogDebug("done highliting child");
s_macDeactivateWindow = NULL;
}
else if ( event.GetActive() )
else if(s_macDeactivateWindow == this)
{
if ( m_frameMenuBar != NULL )
wxLogDebug("Avoided deactivation/activation of this=%p", this);
s_macDeactivateWindow = NULL;
}
else // window to deactivate is NULL or is not us or one of our kids
{
m_frameMenuBar->MacInstallMenuBar() ;
// activate kid instead
if(m_currentChild)
m_currentChild->MacActivate(timestamp,activating);
else
wxFrame::MacActivate(timestamp,activating);
}
}
else
{
// We were scheduled for deactivation, and now we do it.
if(s_macDeactivateWindow==this)
{
s_macDeactivateWindow = NULL;
if(m_currentChild)
m_currentChild->MacActivate(timestamp,activating);
wxFrame::MacActivate(timestamp,activating);
}
else // schedule ourselves for deactivation
{
if(s_macDeactivateWindow)
wxLogDebug("window=%p SHOULD have been deactivated, oh well!",s_macDeactivateWindow);
wxLogDebug("Scheduling delayed MDI Parent deactivation");
s_macDeactivateWindow = this;
}
}
}
}
void wxMDIParentFrame::OnActivate(wxActivateEvent& event)
{
event.Skip();
}
// Returns the active MDI child window
@@ -232,6 +267,10 @@ bool wxMDIChildFrame::Create(wxMDIParentFrame *parent,
wxMDIChildFrame::~wxMDIChildFrame()
{
wxMDIParentFrame *mdiparent = wxDynamicCast(m_parent, wxMDIParentFrame);
wxASSERT(mdiparent);
if(mdiparent->m_currentChild == this)
mdiparent->m_currentChild = NULL;
DestroyChildren();
// already delete by DestroyChildren()
m_frameToolBar = NULL;
@@ -243,6 +282,55 @@ void wxMDIChildFrame::SetMenuBar(wxMenuBar *menu_bar)
return wxFrame::SetMenuBar( menu_bar ) ;
}
void wxMDIChildFrame::MacActivate(long timestamp, bool activating)
{
wxLogDebug("MDI child=%p MacActivate(0x%08lx,%s)",this,timestamp,activating?"ACTIV":"deact");
wxMDIParentFrame *mdiparent = wxDynamicCast(m_parent, wxMDIParentFrame);
wxASSERT(mdiparent);
if(activating)
{
if(s_macDeactivateWindow == m_parent)
{
wxLogDebug("parent had been scheduled for deactivation, rehighlighting");
UMAHighlightAndActivateWindow((WindowRef)s_macDeactivateWindow->MacGetWindowRef(), true);
wxLogDebug("done highliting parent");
s_macDeactivateWindow = NULL;
}
else if((mdiparent->m_currentChild==this) || !s_macDeactivateWindow)
mdiparent->wxFrame::MacActivate(timestamp,activating);
if(mdiparent->m_currentChild && mdiparent->m_currentChild!=this)
mdiparent->m_currentChild->wxFrame::MacActivate(timestamp,false);
mdiparent->m_currentChild = this;
if(s_macDeactivateWindow==this)
{
wxLogDebug("Avoided deactivation/activation of this=%p",this);
s_macDeactivateWindow=NULL;
}
else
wxFrame::MacActivate(timestamp, activating);
}
else
{
// We were scheduled for deactivation, and now we do it.
if(s_macDeactivateWindow==this)
{
s_macDeactivateWindow = NULL;
wxFrame::MacActivate(timestamp,activating);
if(mdiparent->m_currentChild==this)
mdiparent->wxFrame::MacActivate(timestamp,activating);
}
else // schedule ourselves for deactivation
{
if(s_macDeactivateWindow)
wxLogDebug("window=%p SHOULD have been deactivated, oh well!",s_macDeactivateWindow);
wxLogDebug("Scheduling delayed deactivation");
s_macDeactivateWindow = this;
}
}
}
// MDI operations
void wxMDIChildFrame::Maximize()
{