diff --git a/include/wx/cocoa/button.h b/include/wx/cocoa/button.h index 2624033e4a..84acb8607f 100644 --- a/include/wx/cocoa/button.h +++ b/include/wx/cocoa/button.h @@ -58,6 +58,7 @@ protected: public: wxString GetLabel() const; void SetLabel(const wxString& label); + wxSize DoGetBestSize() const; }; #endif // __WX_COCOA_BUTTON_H__ diff --git a/src/cocoa/button.mm b/src/cocoa/button.mm index a4955ccb28..1774dd66ea 100644 --- a/src/cocoa/button.mm +++ b/src/cocoa/button.mm @@ -18,9 +18,10 @@ #include "wx/stockitem.h" #include "wx/cocoa/autorelease.h" +#include "wx/cocoa/string.h" #import -#include "wx/cocoa/string.h" +#import IMPLEMENT_DYNAMIC_CLASS(wxButton, wxControl) BEGIN_EVENT_TABLE(wxButton, wxButtonBase) @@ -79,9 +80,32 @@ void wxButton::SetLabel(const wxString& label) [GetNSButton() setTitle:wxNSStringWithWxString(wxStripMenuCodes(label))]; } -wxSize wxButtonBase::GetDefaultSize() +wxSize wxButton::DoGetBestSize() const { - // FIXME: stub - return wxDefaultSize; + wxSize size = wxButtonBase::DoGetBestSize(); + if(!HasFlag(wxBU_EXACTFIT)) + { + if(size.x<68) + size.x = 68; + } + return size; +} + +static NSRect MakeNSButtonDefaultRect() +{ + // create at (10.0,10.0) with size 20.0x20.0 (just bogus values) + wxObjcAutoRefFromAlloc defaultButton = [[NSButton alloc] + initWithFrame:NSMakeRect(10.0,10.0,20.0,20.0)]; + [defaultButton setBezelStyle:NSRoundedBezelStyle]; + [defaultButton setTitle:@""]; + [defaultButton sizeToFit]; + return [defaultButton frame]; +} + +wxSize wxButtonBase::GetDefaultSize() +{ + static NSRect cocoaRect = MakeNSButtonDefaultRect(); + // Apple HIG says OK/Cancel buttons have default width of 68. + return wxSize(68,(int)ceilf(cocoaRect.size.height)); }