X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b2da87c3169f29e3e0a317e8de12f6de045e4126..0356c2597ec9f604918c880e3057650a7bf467f6:/src/motif/spinbutt.cpp?ds=sidebyside diff --git a/src/motif/spinbutt.cpp b/src/motif/spinbutt.cpp index ba88785d9b..cdded68c3a 100644 --- a/src/motif/spinbutt.cpp +++ b/src/motif/spinbutt.cpp @@ -9,10 +9,17 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "spinbutt.h" #endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + +#include "wx/defs.h" + +#if wxUSE_SPINBTN + #include "wx/spinbutt.h" #include "wx/spinctrl.h" #include "wx/timer.h" @@ -74,7 +81,7 @@ class wxArrowButton : public wxControl { friend class wxArrowButtonTimer; public: - wxArrowButton( int increment ) + wxArrowButton( int increment ) : m_increment( increment ), m_timer( 0 ) {} @@ -183,7 +190,7 @@ bool wxArrowButton::Create( wxSpinButton* parent, wxWindowID id, ArrowDirection d, const wxPoint& pos, const wxSize& size ) { - int arrow_dir; + int arrow_dir = XmARROW_UP; switch( d ) { @@ -209,6 +216,7 @@ bool wxArrowButton::Create( wxSpinButton* parent, wxWindowID id, parentWidget, XmNarrowDirection, arrow_dir, XmNborderWidth, 0, + XmNshadowThickness, 0, NULL ); XtAddCallback( (Widget) m_mainWidget, @@ -224,7 +232,9 @@ bool wxArrowButton::Create( wxSpinButton* parent, wxWindowID id, AttachWidget( parent, m_mainWidget, (WXWidget) NULL, pos.x, pos.y, size.x, size.y ); - return TRUE; + SetForegroundColour( parent->GetBackgroundColour() ); + + return true; } // ---------------------------------------------------------------------------- @@ -266,26 +276,24 @@ bool wxSpinButton::Create( wxWindow *parent, wxWindowID id, if( !wxControl::Create( parent, id, pos, newSize, style ) ) { - return FALSE; + return false; } SetName(name); - InitBase(); - - m_windowId = ( id == -1 ) ? NewControlId() : id; + m_windowId = ( id == wxID_ANY ) ? NewControlId() : id; bool isVert = IsVertical(); wxPoint pt1, pt2; wxSize sz1, sz2; CalcSizes( wxPoint(0,0), newSize, pt1, sz1, pt2, sz2, isVert ); - m_up = new wxArrowButton( this, -1, isVert ? wxARROW_UP : wxARROW_LEFT, + m_up = new wxArrowButton( this, -1, isVert ? wxARROW_UP : wxARROW_RIGHT, pt1, sz1, 1 ); m_down = new wxArrowButton( this, -1, - isVert ? wxARROW_DOWN : wxARROW_RIGHT, + isVert ? wxARROW_DOWN : wxARROW_LEFT, pt2, sz2, -1 ); - return TRUE; + return true; } wxSpinButton::~wxSpinButton() @@ -331,14 +339,14 @@ void wxSpinButton::Increment( int delta ) if( npos < m_min ) { - if( GetWindowStyle() && wxSP_WRAP ) + if( GetWindowStyle() & wxSP_WRAP ) npos = m_max; else npos = m_min; } if( npos > m_max ) { - if( GetWindowStyle() && wxSP_WRAP ) + if( GetWindowStyle() & wxSP_WRAP ) npos = m_min; else npos = m_max; @@ -364,7 +372,7 @@ void wxSpinButton::Increment( int delta ) wxSize wxSpinButton::DoGetBestSize() const { - return IsVertical() ? wxSize( 24, 34 ) : wxSize( 34, 24 ); + return IsVertical() ? wxSize( 20, 30 ) : wxSize( 30, 20 ); } // Attributes @@ -399,3 +407,5 @@ void wxSpinButton::ChangeForegroundColour() { // TODO } + +#endif // wxUSE_SPINBTN