#pragma implementation "bmpbuttn.h"
#endif
+#ifdef __VMS
+#define XtScreen XTSCREEN
+#endif
+
+#include "wx/defs.h"
+
#include "wx/bmpbuttn.h"
#ifdef __VMS__
Pixmap XCreateInsensitivePixmap( Display *display, Pixmap pixmap );
-#if !USE_SHARED_LIBRARY
IMPLEMENT_DYNAMIC_CLASS(wxBitmapButton, wxButton)
-#endif
wxBitmapButton::wxBitmapButton()
{
(XtPointer) this);
SetCanAddEventHandler(TRUE);
- AttachWidget (parent, m_mainWidget, (WXWidget) NULL, pos.x, pos.y, size.x, size.y);
+
+ wxSize newSize = size;
+
+ if (m_buttonBitmap.Ok())
+ {
+ int border = (style & wxNO_BORDER) ? 4 : 10;
+ if (newSize.x == -1)
+ newSize.x = m_buttonBitmap.GetWidth()+border;
+ if (newSize.y == -1)
+ newSize.y = m_buttonBitmap.GetHeight()+border;
+ }
+
+ AttachWidget (parent, m_mainWidget, (WXWidget) NULL, pos.x, pos.y, newSize.x, newSize.y);
return TRUE;
}
// Must reset the bitmaps since the colours have changed.
DoSetBitmap();
}
+
+wxSize wxBitmapButton::DoGetBestSize() const
+{
+ wxSize ret( 30,30 );
+
+ if (m_buttonBitmap.Ok())
+ {
+ int border = (GetWindowStyle() & wxNO_BORDER) ? 4 : 10;
+ ret.x = m_buttonBitmap.GetWidth()+border;
+ ret.y = m_buttonBitmap.GetHeight()+border;
+ }
+
+ if (!HasFlag(wxBU_EXACTFIT))
+ {
+ if (ret.x < 80) ret.x = 80;
+ }
+
+ return ret;
+}
+