#include "wx/log.h"
#endif
+#include "wx/stockitem.h"
#include "wx/cocoa/autorelease.h"
+#include "wx/cocoa/string.h"
#import <AppKit/NSButton.h>
-#include "wx/cocoa/string.h"
+#import <math.h>
IMPLEMENT_DYNAMIC_CLASS(wxButton, wxControl)
BEGIN_EVENT_TABLE(wxButton, wxButtonBase)
WX_IMPLEMENT_COCOA_OWNER(wxButton,NSButton,NSControl,NSView)
bool wxButton::Create(wxWindow *parent, wxWindowID winid,
- const wxString& label, const wxPoint& pos,
+ const wxString& lbl, const wxPoint& pos,
const wxSize& size, long style,
const wxValidator& validator, const wxString& name)
{
+ wxString label((lbl.empty() && wxIsStockID(winid))?wxGetStockLabel(winid):lbl);
+
wxAutoNSAutoreleasePool pool;
wxLogTrace(wxTRACE_COCOA,wxT("Creating control with id=%d"),winid);
if(!CreateControl(parent,winid,pos,size,style,validator,name))
[GetNSButton() setTitle:wxNSStringWithWxString(wxStripMenuCodes(label))];
}
+wxSize wxButton::DoGetBestSize() const
+{
+ 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<NSButton*> defaultButton = [[NSButton alloc]
+ initWithFrame:NSMakeRect(10.0,10.0,20.0,20.0)];
+ [static_cast<NSButton*>(defaultButton) setBezelStyle:NSRoundedBezelStyle];
+ [static_cast<NSButton*>(defaultButton) setTitle:@""];
+ [static_cast<NSButton*>(defaultButton) sizeToFit];
+ return [static_cast<NSButton*>(defaultButton) frame];
+}
+
wxSize wxButtonBase::GetDefaultSize()
{
- // FIXME: stub
- return wxDefaultSize;
+ static NSRect cocoaRect = MakeNSButtonDefaultRect();
+ // Apple HIG says OK/Cancel buttons have default width of 68.
+ return wxSize(68,(int)ceil(cocoaRect.size.height));
}