@implementation wxNSBox
-- (void)setImplementation: (wxWidgetCocoaImpl *) theImplementation
++ (void)initialize
{
- impl = theImplementation;
+ static BOOL initialized = NO;
+ if (!initialized)
+ {
+ initialized = YES;
+ wxOSXCocoaClassAddWXMethods( self );
+ }
}
-- (wxWidgetCocoaImpl*) implementation
-{
- return impl;
-}
+@end
-- (BOOL) isFlipped
+namespace
{
- return NO;
-}
+ 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
-@end
-wxWidgetImplType* wxWidgetImpl::CreateGroupBox( wxWindowMac* wxpeer,
- wxWindowMac* parent,
- wxWindowID id,
- const wxString& label,
- const wxPoint& pos,
+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;
}