@implementation wxNSBox
-WXCOCOAIMPL_COMMON_IMPLEMENTATION
++ (void)initialize
+{
+ static BOOL initialized = NO;
+ if (!initialized)
+ {
+ initialized = YES;
+ wxOSXCocoaClassAddWXMethods( self );
+ }
+}
@end
-wxWidgetImplType* wxWidgetImpl::CreateGroupBox( wxWindowMac* wxpeer,
- wxWindowMac* parent,
- wxWindowID id,
- const wxString& label,
- const wxPoint& pos,
+namespace
+{
+ class wxStaticBoxCocoaImpl : public wxWidgetCocoaImpl
+ {
+ public:
+ wxStaticBoxCocoaImpl(wxWindowMac *wxpeer, wxNSBox *v)
+ : wxWidgetCocoaImpl(wxpeer, v)
+ {
+ }
+
+ virtual void SetLabel( const wxString& title, wxFontEncoding encoding )
+ {
+ if (title.empty())
+ [GetNSBox() setTitlePosition:NSNoTitle];
+ else
+ [GetNSBox() setTitlePosition:NSAtTop];
+
+ wxWidgetCocoaImpl::SetLabel(title, encoding);
+ }
+
+ private:
+ NSBox *GetNSBox() const
+ {
+ wxASSERT( [m_osxView isKindOfClass:[NSBox class]] );
+
+ return static_cast<NSBox*>(m_osxView);
+ }
+ };
+} // anonymous namespace
+
+
+wxWidgetImplType* wxWidgetImpl::CreateGroupBox( wxWindowMac* wxpeer,
+ wxWindowMac* WXUNUSED(parent),
+ wxWindowID WXUNUSED(id),
+ const wxString& WXUNUSED(label),
+ const wxPoint& pos,
const wxSize& size,
- long style,
- long extraStyle)
+ long WXUNUSED(style),
+ long WXUNUSED(extraStyle))
{
NSRect r = wxOSXGetFrameForControl( wxpeer, pos , size ) ;
wxNSBox* v = [[wxNSBox alloc] initWithFrame:r];
- wxWidgetCocoaImpl* c = new wxWidgetCocoaImpl( wxpeer, v );
- [v setImplementation:c];
+ wxStaticBoxCocoaImpl* c = new wxStaticBoxCocoaImpl( wxpeer, v );
+ c->SetFlipped(false);
return c;
}