// Licence: wxWindows license
/////////////////////////////////////////////////////////////////////////////
-#include "wx/app.h"
-#include "wx/statbox.h"
+#include "wx/wxprec.h"
+#ifndef WX_PRECOMP
+ #include "wx/app.h"
+ #include "wx/statbox.h"
+#endif //WX_PRECOMP
+
+#include "wx/cocoa/autorelease.h"
+#include "wx/cocoa/string.h"
#import <AppKit/NSBox.h>
#import <Foundation/NSString.h>
long style, const wxValidator& validator,
const wxString& name)
{
+ wxAutoNSAutoreleasePool pool;
if(!CreateControl(parent,winid,pos,size,style,validator,name))
return false;
m_cocoaNSView = NULL;
- SetNSBox([[NSBox alloc] initWithFrame:NSMakeRect(0,0,30,30)]);
- [GetNSBox() setTitle:[NSString stringWithCString:title.c_str()]];
+ SetNSBox([[NSBox alloc] initWithFrame:MakeDefaultNSRect(size)]);
+ [GetNSBox() setTitle:wxNSStringWithWxString(wxStripMenuCodes(title))];
if(m_parent)
m_parent->CocoaAddChild(this);
+ SetInitialFrameRect(pos,size);
+
return true;
}
wxStaticBox::~wxStaticBox()
{
- CocoaRemoveFromParent();
- SetNSBox(NULL);
+ DisassociateNSBox(GetNSBox());
+}
+
+void wxStaticBox::GetBordersForSizer(int *borderTop, int *borderOther) const
+{
+ NSRect contentRect = [[GetNSBox() contentView] frame];
+ NSRect thisRect = [m_cocoaNSView frame];
+ *borderTop = (int)(thisRect.size.height - (contentRect.origin.y+contentRect.size.height));
+ *borderOther = (int)(thisRect.size.width - (contentRect.origin.x+contentRect.size.width));
+ int nextBorder = (int)contentRect.origin.y;
+ if(nextBorder > *borderOther)
+ *borderOther = nextBorder;
+ nextBorder = (int)contentRect.origin.x;
+ if(nextBorder > *borderOther)
+ *borderOther = nextBorder;
}