git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36658
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
IMPLEMENT_DYNAMIC_CLASS(wxFrame, wxTopLevelWindow)
#define WX_MAC_STATUSBAR_HEIGHT 18
IMPLEMENT_DYNAMIC_CLASS(wxFrame, wxTopLevelWindow)
#define WX_MAC_STATUSBAR_HEIGHT 18
// ----------------------------------------------------------------------------
// creation/destruction
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// creation/destruction
// ----------------------------------------------------------------------------
void wxFrame::Init()
{
m_frameMenuBar = NULL;
void wxFrame::Init()
{
m_frameMenuBar = NULL;
+ m_frameStatusBar = NULL;
+ m_winLastFocused = NULL;
- m_frameToolBar = NULL ;
- m_frameStatusBar = NULL;
- m_winLastFocused = NULL ;
-
- m_iconized = false;
+ // NB: is this used anywhere?
+ m_hwndToolTip = NULL;
}
bool wxFrame::Create(wxWindow *parent,
}
bool wxFrame::Create(wxWindow *parent,
wxPoint wxFrame::GetClientAreaOrigin() const
{
wxPoint pt = wxTopLevelWindow::GetClientAreaOrigin();
wxPoint wxFrame::GetClientAreaOrigin() const
{
wxPoint pt = wxTopLevelWindow::GetClientAreaOrigin();
#if wxUSE_TOOLBAR && !defined(__WXUNIVERSAL__)
wxToolBar *toolbar = GetToolBar();
if ( toolbar && toolbar->IsShown() )
{
int w, h;
toolbar->GetSize(&w, &h);
#if wxUSE_TOOLBAR && !defined(__WXUNIVERSAL__)
wxToolBar *toolbar = GetToolBar();
if ( toolbar && toolbar->IsShown() )
{
int w, h;
toolbar->GetSize(&w, &h);
if ( toolbar->GetWindowStyleFlag() & wxTB_VERTICAL )
{
pt.x += w;
if ( toolbar->GetWindowStyleFlag() & wxTB_VERTICAL )
{
pt.x += w;
if ( m_frameMenuBar && m_frameMenuBar == wxMenuBar::MacGetInstalledMenuBar() )
{
if ( m_frameMenuBar && m_frameMenuBar == wxMenuBar::MacGetInstalledMenuBar() )
{
- int iMaxMenu = m_frameMenuBar->GetMenuCount();
+ int iMaxMenu = m_frameMenuBar->GetMenuCount();
for ( int i = 0 ; i < iMaxMenu ; ++ i )
{
m_frameMenuBar->EnableTop( i , enable ) ;
for ( int i = 0 ; i < iMaxMenu ; ++ i )
{
m_frameMenuBar->EnableTop( i , enable ) ;
wxStatusBar *wxFrame::OnCreateStatusBar(int number, long style, wxWindowID id,
const wxString& name)
{
wxStatusBar *wxFrame::OnCreateStatusBar(int number, long style, wxWindowID id,
const wxString& name)
{
- wxStatusBar *statusBar = NULL;
+ wxStatusBar *statusBar;
- statusBar = new wxStatusBar(this, id,
- style, name);
- statusBar->SetSize( 100 , WX_MAC_STATUSBAR_HEIGHT ) ;
+ statusBar = new wxStatusBar(this, id, style, name);
+ statusBar->SetSize(100 , WX_MAC_STATUSBAR_HEIGHT);
statusBar->SetFieldsCount(number);
statusBar->SetFieldsCount(number);
if ( m_frameStatusBar )
{
wxSysColourChangedEvent event2;
if ( m_frameStatusBar )
{
wxSysColourChangedEvent event2;
event2.SetEventObject( m_frameStatusBar );
m_frameStatusBar->ProcessEvent(event2);
}
event2.SetEventObject( m_frameStatusBar );
m_frameStatusBar->ProcessEvent(event2);
}
wxWindow::OnSysColourChanged(event);
}
wxWindow::OnSysColourChanged(event);
}
// Default activation behaviour - set the focus for the first child
// subwindow found.
void wxFrame::OnActivate(wxActivateEvent& event)
// Default activation behaviour - set the focus for the first child
// subwindow found.
void wxFrame::OnActivate(wxActivateEvent& event)
if ( win->IsTopLevel() )
{
if ( win != this )
if ( win->IsTopLevel() )
{
if ( win != this )
else
{
// restore focus to the child which was last focused
else
{
// restore focus to the child which was last focused
- wxWindow *parent = m_winLastFocused ? m_winLastFocused->GetParent()
- : NULL;
+ wxWindow *parent = m_winLastFocused
+ ? m_winLastFocused->GetParent()
+ : NULL;
+
wxSetFocusToChild(parent, &m_winLastFocused);
wxSetFocusToChild(parent, &m_winLastFocused);
- if ( m_frameMenuBar != NULL )
+ if (m_frameMenuBar != NULL)
{
m_frameMenuBar->MacInstallMenuBar() ;
}
else if (wxTheApp->GetTopWindow() && wxTheApp->GetTopWindow()->IsKindOf(CLASSINFO(wxFrame)))
{
{
m_frameMenuBar->MacInstallMenuBar() ;
}
else if (wxTheApp->GetTopWindow() && wxTheApp->GetTopWindow()->IsKindOf(CLASSINFO(wxFrame)))
{
- // Trying toplevel frame menbar
- if( ((wxFrame*)wxTheApp->GetTopWindow())->GetMenuBar() )
+ // Trying toplevel frame membar
+ if (((wxFrame*)wxTheApp->GetTopWindow())->GetMenuBar())
((wxFrame*)wxTheApp->GetTopWindow())->GetMenuBar()->MacInstallMenuBar();
}
}
((wxFrame*)wxTheApp->GetTopWindow())->GetMenuBar()->MacInstallMenuBar();
}
}
void wxFrame::DetachMenuBar()
{
if ( m_frameMenuBar )
void wxFrame::DetachMenuBar()
{
if ( m_frameMenuBar )
m_frameMenuBar->UnsetInvokingWindow();
m_frameMenuBar->UnsetInvokingWindow();
wxFrameBase::DetachMenuBar();
}
wxFrameBase::DetachMenuBar();
}
wxFrameBase::AttachMenuBar(menuBar);
if (m_frameMenuBar)
wxFrameBase::AttachMenuBar(menuBar);
if (m_frameMenuBar)
m_frameMenuBar->SetInvokingWindow( this );
m_frameMenuBar->SetInvokingWindow( this );
}
void wxFrame::DoGetClientSize(int *x, int *y) const
{
}
void wxFrame::DoGetClientSize(int *x, int *y) const
{
- wxTopLevelWindow::DoGetClientSize( x , y ) ;
+ wxTopLevelWindow::DoGetClientSize( x , y );
#if wxUSE_STATUSBAR
if ( GetStatusBar() && GetStatusBar()->IsShown() && y )
#if wxUSE_STATUSBAR
if ( GetStatusBar() && GetStatusBar()->IsShown() && y )
*y -= WX_MAC_STATUSBAR_HEIGHT;
*y -= WX_MAC_STATUSBAR_HEIGHT;
- }
-#endif // wxUSE_STATUSBAR
#if wxUSE_TOOLBAR
wxToolBar *toolbar = GetToolBar();
#if wxUSE_TOOLBAR
wxToolBar *toolbar = GetToolBar();
if ( toolbar->GetWindowStyleFlag() & wxTB_VERTICAL )
{
if ( toolbar->GetWindowStyleFlag() & wxTB_VERTICAL )
{
}
else
{
#if !wxMAC_USE_NATIVE_TOOLBAR
}
else
{
#if !wxMAC_USE_NATIVE_TOOLBAR
}
bool wxFrame::MacIsChildOfClientArea( const wxWindow* child ) const
}
bool wxFrame::MacIsChildOfClientArea( const wxWindow* child ) const
#if wxUSE_STATUSBAR
if ( child == GetStatusBar() )
return false ;
#if wxUSE_STATUSBAR
if ( child == GetStatusBar() )
return false ;
-#endif // wxUSE_STATUSBAR
#if wxUSE_TOOLBAR
if ( child == GetToolBar() )
return false ;
#if wxUSE_TOOLBAR
if ( child == GetToolBar() )
return false ;
return wxFrameBase::MacIsChildOfClientArea( child ) ;
}
return wxFrameBase::MacIsChildOfClientArea( child ) ;
}
// find the current client size
// find the current client size
- // Find the difference between the entire window (title bar and all)
- // and the client area; add this to the new client size to move the
- // window
-
+ // Find the difference between the entire window (title bar and all) and
+ // the client area; add this to the new client size to move the window
DoSetSize( -1 , -1 , currentwidth + clientwidth - currentclientwidth ,
currentheight + clientheight - currentclientheight , wxSIZE_USE_EXISTING ) ;
}
DoSetSize( -1 , -1 , currentwidth + clientwidth - currentclientwidth ,
currentheight + clientheight - currentclientheight , wxSIZE_USE_EXISTING ) ;
}
#if wxUSE_TOOLBAR
void wxFrame::SetToolBar(wxToolBar *toolbar)
{
#if wxUSE_TOOLBAR
void wxFrame::SetToolBar(wxToolBar *toolbar)
{
#if wxMAC_USE_NATIVE_TOOLBAR
if ( m_frameToolBar )
#if wxMAC_USE_NATIVE_TOOLBAR
if ( m_frameToolBar )
- m_frameToolBar->MacInstallNativeToolbar(false) ;
+ m_frameToolBar->MacInstallNativeToolbar( false ) ;
m_frameToolBar = toolbar ;
m_frameToolBar = toolbar ;
#if wxMAC_USE_NATIVE_TOOLBAR
if ( toolbar )
toolbar->MacInstallNativeToolbar( true ) ;
#if wxMAC_USE_NATIVE_TOOLBAR
if ( toolbar )
toolbar->MacInstallNativeToolbar( true ) ;
wxToolBar* wxFrame::CreateToolBar(long style, wxWindowID id, const wxString& name)
{
if ( wxFrameBase::CreateToolBar(style, id, name) )
wxToolBar* wxFrame::CreateToolBar(long style, wxWindowID id, const wxString& name)
{
if ( wxFrameBase::CreateToolBar(style, id, name) )
- if ( GetStatusBar() && GetStatusBar()->IsShown())
+ if (GetStatusBar() && GetStatusBar()->IsShown())
- int statusX, statusY;
- GetStatusBar()->GetClientSize(&statusX, &statusY);
- ch -= statusY;
+ int statusX, statusY;
+
+ GetStatusBar()->GetClientSize(&statusX, &statusY);
+ ch -= statusY;
}
if (GetToolBar())
{
int tx, ty, tw, th;
}
if (GetToolBar())
{
int tx, ty, tw, th;
- GetToolBar()->GetSize(& tw, & th);
+ tx = ty = 0 ;
+ GetToolBar()->GetSize(&tw, &th);
if (GetToolBar()->GetWindowStyleFlag() & wxTB_VERTICAL)
{
// Use the 'real' position. wxSIZE_NO_ADJUSTMENTS
if (GetToolBar()->GetWindowStyleFlag() & wxTB_VERTICAL)
{
// Use the 'real' position. wxSIZE_NO_ADJUSTMENTS