// Licence: wxWindows license
/////////////////////////////////////////////////////////////////////////////
-#include "wx/frame.h"
-#include "wx/menu.h"
-#include "wx/menuitem.h"
-#include "wx/app.h"
-#include "wx/log.h"
-#include "wx/statusbr.h"
+#include "wx/wxprec.h"
+#ifndef WX_PRECOMP
+ #include "wx/log.h"
+ #include "wx/app.h"
+ #include "wx/frame.h"
+ #include "wx/menu.h"
+ #include "wx/toolbar.h"
+ #include "wx/statusbr.h"
+#endif // WX_PRECOMP
+
+#include "wx/cocoa/autorelease.h"
+#include "wx/cocoa/mbarman.h"
#import <AppKit/NSWindow.h>
#import <AppKit/NSApplication.h>
+#import <AppKit/NSView.h>
// wxFrame
void wxFrame::Init()
{
+ m_frameNSView = nil;
}
bool wxFrame::Create(wxWindow *parent,
wxFrame::~wxFrame()
{
-}
-
-void wxFrame::Cocoa_wxMenuItemAction(wxMenuItem& item)
-{
- Command(item.GetId());
+ [m_frameNSView release];
}
void wxFrame::AttachMenuBar(wxMenuBar *mbar)
{
wxFrameBase::AttachMenuBar(mbar);
- if(m_frameMenuBar)
- {
- wxLogDebug("Attached menu");
- [m_cocoaNSWindow setMenu:m_frameMenuBar->GetNSMenu()];
- }
+ wxMenuBarManager::GetInstance()->UpdateWindowMenuBar(this);
}
void wxFrame::DetachMenuBar()
{
- if(m_frameMenuBar)
+ wxFrameBase::DetachMenuBar();
+ wxMenuBarManager::GetInstance()->UpdateWindowMenuBar(this);
+}
+
+void wxFrame::SetMenuBar(wxMenuBar *menubar)
+{
+ if ( menubar == GetMenuBar() )
{
- [m_cocoaNSWindow setMenu:nil];
+ // nothing to do
+ return;
}
+
wxFrameBase::DetachMenuBar();
+ wxFrameBase::AttachMenuBar(menubar);
+ wxMenuBarManager::GetInstance()->UpdateWindowMenuBar(this);
}
-bool wxFrame::Show(bool show)
+wxPoint wxFrame::GetClientAreaOrigin() const
{
- bool ret = wxFrameBase::Show(show);
- if(show && GetMenuBar())
- [wxTheApp->GetNSApplication() setMenu:GetMenuBar()->GetNSMenu() ];
- return ret;
+ return wxPoint(0,0);
}
-void wxFrame::Cocoa_FrameChanged(void)
+void wxFrame::CocoaSetWxWindowSize(int width, int height)
{
- PositionStatusBar();
- wxFrameBase::Cocoa_FrameChanged();
+ if(m_frameStatusBar)
+ height += m_frameStatusBar->GetSize().y;
+#if wxUSE_TOOLBAR
+ if(m_frameToolBar)
+ height += m_frameToolBar->GetSize().y;
+#endif //wxUSE_TOOLBAR
+ wxTopLevelWindow::CocoaSetWxWindowSize(width,height);
}
-wxPoint wxFrame::GetClientAreaOrigin() const
+WX_NSView wxFrame::GetNonClientNSView()
{
- return wxPoint(0,0);
+ if(m_frameNSView)
+ return m_frameNSView;
+ return GetNSViewForSuperview();
}
-void wxFrame::DoGetClientSize(int *width, int *height) const
+void wxFrame::CocoaReplaceView(WX_NSView oldView, WX_NSView newView)
{
- wxFrameBase::DoGetClientSize(width,height);
- if(height)
+ // If we have the additional toolbar/statbar view, then the
+ // default replaceSubview will work. Otherwise, the old view
+ // should be the content view and should be replaced that way
+ if(m_frameNSView)
+ wxWindow::CocoaReplaceView(oldView, newView);
+ else
+ wxTopLevelWindow::CocoaReplaceView(oldView, newView);
+}
+
+void wxFrame::UpdateFrameNSView()
+{
+ if(!m_frameNSView)
+ {
+ m_frameNSView = [[NSView alloc] initWithFrame:[[m_cocoaNSWindow contentView] frame]];
+ [m_cocoaNSWindow setContentView: m_frameNSView];
+ [m_frameNSView addSubview:m_cocoaNSView];
+ }
+ NSRect frameRect = [m_frameNSView frame];
+ float tbarheight = 0.0;
+#if wxUSE_TOOLBAR
+ if(m_frameToolBar)
+ {
+ NSView *tbarNSView = m_frameToolBar->GetNSViewForSuperview();
+ if(![tbarNSView superview])
+ [m_frameNSView addSubview: tbarNSView];
+ NSRect tbarRect = [tbarNSView frame];
+ tbarRect.size.width = frameRect.size.width;
+ tbarRect.origin.x = 0.0;
+ tbarRect.origin.y = frameRect.size.height - tbarRect.size.height;
+ [tbarNSView setFrame:tbarRect];
+ // width expands, bottom margin expands
+ [tbarNSView setAutoresizingMask: NSViewWidthSizable|NSViewMinYMargin];
+ tbarheight = tbarRect.size.height;
+ }
+#endif //wxUSE_TOOLBAR
+ float sbarheight = 0.0;
+ if(m_frameStatusBar)
{
- if(m_frameStatusBar && m_frameStatusBar->IsShown())
- *height -= m_frameStatusBar->GetSize().y;
+ NSView *sbarNSView = m_frameStatusBar->GetNSViewForSuperview();
+ if(![sbarNSView superview])
+ [m_frameNSView addSubview: sbarNSView];
+ NSRect sbarRect = [sbarNSView frame];
+ sbarRect.size.width = frameRect.size.width;
+ sbarRect.origin.x = 0.0;
+ sbarRect.origin.y = 0.0;
+ [sbarNSView setFrame:sbarRect];
+ // width expands, top margin expands
+ [sbarNSView setAutoresizingMask: NSViewWidthSizable|NSViewMaxYMargin];
+ sbarheight = sbarRect.size.height;
}
+ wxLogDebug("frame height=%f, tbar=%f, sbar=%f",frameRect.size.height,tbarheight,sbarheight);
+ NSRect innerRect = [m_cocoaNSView frame];
+ innerRect.size.height = frameRect.size.height - tbarheight - sbarheight;
+ innerRect.origin.y = sbarheight;
+ [m_cocoaNSView setFrame:innerRect];
+ [m_cocoaNSView setAutoresizingMask: NSViewWidthSizable|NSViewHeightSizable];
+ // Don't let the frame get smaller than the toolbar+statusbar height
+ NSRect frameMinRect = [NSWindow frameRectForContentRect:
+ NSMakeRect(0.0,0.0,0.0,tbarheight+sbarheight)
+ styleMask: [m_cocoaNSWindow styleMask]];
+ [m_cocoaNSWindow setMinSize:frameMinRect.size];
}
-void wxFrame::DoSetClientSize(int width, int height)
+void wxFrame::SetStatusBar(wxStatusBar *statusbar)
{
- if(m_frameStatusBar && m_frameStatusBar->IsShown())
- height += m_frameStatusBar->GetSize().y;
- wxFrameBase::DoSetClientSize(width,height);
+ if(m_frameStatusBar)
+ {
+ [m_frameStatusBar->GetNSViewForSuperview() removeFromSuperview];
+ [m_frameStatusBar->GetNSViewForSuperview() setAutoresizingMask: NSViewMinYMargin];
+ if(m_frameStatusBar->GetParent())
+ m_frameStatusBar->GetParent()->CocoaAddChild(m_frameStatusBar);
+ }
+ m_frameStatusBar = statusbar;
+ if(m_frameStatusBar)
+ {
+ m_frameStatusBar->CocoaRemoveFromParent();
+ }
+ UpdateFrameNSView();
}
-void wxFrame::PositionStatusBar()
+wxStatusBar* wxFrame::CreateStatusBar(int number,
+ long style,
+ wxWindowID winid,
+ const wxString& name)
{
- if( !m_frameStatusBar || !m_frameStatusBar->IsShown() )
- return;
+ wxFrameBase::CreateStatusBar(number,style,winid,name);
+ if(m_frameStatusBar)
+ {
+ m_frameStatusBar->CocoaRemoveFromParent();
+ }
+ UpdateFrameNSView();
+ return m_frameStatusBar;
+}
- // Get the client size. Since it excludes the StatusBar area we want
- // the top of the status bar to be directly under it (thus located at h)
- // The width of the statusbar should then match the client width
- int w, h;
- GetClientSize(&w, &h);
+#if wxUSE_TOOLBAR
+void wxFrame::SetToolBar(wxToolBar *toolbar)
+{
+ if(m_frameToolBar)
+ {
+ [m_frameToolBar->GetNSViewForSuperview() removeFromSuperview];
+ [m_frameToolBar->GetNSViewForSuperview() setAutoresizingMask: NSViewMinYMargin];
+ if(m_frameToolBar->GetParent())
+ m_frameToolBar->GetParent()->CocoaAddChild(m_frameToolBar);
+ }
+ m_frameToolBar = toolbar;
+ if(m_frameToolBar)
+ {
+ m_frameToolBar->CocoaRemoveFromParent();
+ }
+ UpdateFrameNSView();
+}
- int sh;
- m_frameStatusBar->GetSize(NULL, &sh);
+wxToolBar* wxFrame::CreateToolBar(long style,
+ wxWindowID winid,
+ const wxString& name)
+{
+ wxFrameBase::CreateToolBar(style,winid,name);
+ if(m_frameToolBar)
+ {
+ m_frameToolBar->CocoaRemoveFromParent();
+ }
+ UpdateFrameNSView();
+ return m_frameToolBar;
+}
+#endif // wxUSE_TOOLBAR
- m_frameStatusBar->SetSize(0, h, w, sh);
+void wxFrame::PositionStatusBar()
+{
}