// Author: Stefan Csomor
// Modified by:
// Created: 1998-01-01
-// RCS-ID: $Id: button.cpp 54845 2008-07-30 14:52:41Z SC $
+// RCS-ID: $Id$
// Copyright: (c) Stefan Csomor
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#include "wx/panel.h"
#include "wx/toplevel.h"
#include "wx/dcclient.h"
+ #include "wx/stattext.h"
#endif
#include "wx/stockitem.h"
#include "wx/osx/private.h"
+namespace
+{
+
+// Returns true only if the id is wxID_HELP and the label is "Help" or empty.
+bool IsHelpButtonWithStandardLabel(wxWindowID id, const wxString& label)
+{
+ if ( id != wxID_HELP )
+ return false;
+
+ if ( label.empty() )
+ return true;
+
+ const wxString labelText = wxStaticText::GetLabelText(label);
+ return labelText == "Help" || labelText == _("Help");
+}
+
+} // anonymous namespace
+
IMPLEMENT_DYNAMIC_CLASS(wxButton, wxControl)
BEGIN_EVENT_TABLE(wxButton, wxControl)
bool wxButton::Create(wxWindow *parent,
wxWindowID id,
- const wxString& lbl,
+ const wxString& labelOrig,
const wxPoint& pos,
const wxSize& size,
long style,
validator, name);
}
- wxString label(lbl);
- if (label.empty() && wxIsStockID(id) && !(id == wxID_HELP))
- label = wxGetStockLabel(id);
+ wxString label;
+
+ // Ignore the standard label for help buttons if possible, they use "?"
+ // label under Mac which looks better.
+ if ( !IsHelpButtonWithStandardLabel(id, labelOrig) )
+ {
+ label = labelOrig.empty() && wxIsStockID(id) ? wxGetStockLabel(id)
+ : labelOrig;
+ }
m_macIsUserPane = false ;
void wxButton::SetLabel(const wxString& label)
{
- if ( GetId() == wxID_HELP || HasFlag(wxBU_NOTEXT) )
+ if ( IsHelpButtonWithStandardLabel(GetId(), label) )
+ {
+ // ignore the standard label for the help buttons, it's not used
+ return;
+ }
+
+ if ( HasFlag(wxBU_NOTEXT) )
{
// just store the label internally but don't really use it for the
// button
void wxButton::DoSetBitmap(const wxBitmap& bitmap, State which)
{
m_bitmaps[which] = bitmap;
-
+
if ( which == State_Normal )
m_peer->SetBitmap(bitmap);
else if ( which == State_Pressed )
if ( bi )
bi->SetPressedBitmap(bitmap);
}
+ InvalidateBestSize();
}
void wxButton::DoSetBitmapPosition(wxDirection dir)
{
m_peer->SetBitmapPosition(dir);
+ InvalidateBestSize();
}
wxWindow *wxButton::SetDefault()
void wxButton::OnEnterWindow( wxMouseEvent& WXUNUSED(event))
{
if ( DoGetBitmap( State_Current ).IsOk() )
- m_peer->SetBitmap( DoGetBitmap( State_Current ) );
+ m_peer->SetBitmap( DoGetBitmap( State_Current ) );
}
void wxButton::OnLeaveWindow( wxMouseEvent& WXUNUSED(event))
{
if ( DoGetBitmap( State_Current ).IsOk() )
- m_peer->SetBitmap( DoGetBitmap( State_Normal ) );
+ m_peer->SetBitmap( DoGetBitmap( State_Normal ) );
}
bool wxButton::OSXHandleClicked( double WXUNUSED(timestampsec) )