X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9453cf2bd702241fabc417e9dd5cd7422bcd9966..53fdeb16a862d0fbba3e3829e9c8f56e402b03ce:/src/generic/spinctlg.cpp?ds=inline diff --git a/src/generic/spinctlg.cpp b/src/generic/spinctlg.cpp index 5c02451b72..3488d1f074 100644 --- a/src/generic/spinctlg.cpp +++ b/src/generic/spinctlg.cpp @@ -35,6 +35,8 @@ #include "wx/textctrl.h" #endif //WX_PRECOMP +#if wxUSE_SPINCTRL + #include "wx/spinbutt.h" #include "wx/spinctrl.h" @@ -70,6 +72,15 @@ protected: event.Skip(); } + bool ProcessEvent(wxEvent &event) + { + // Hand button down events to wxSpinCtrl. Doesn't work. + if (event.GetEventType() == wxEVT_LEFT_DOWN && m_spin->ProcessEvent( event )) + return TRUE; + + return wxTextCtrl::ProcessEvent( event ); + } + private: wxSpinCtrl *m_spin; @@ -92,7 +103,7 @@ public: { m_spin = spin; - SetWindowStyle(style); + SetWindowStyle(style | wxSP_VERTICAL); } protected: @@ -146,16 +157,31 @@ bool wxSpinCtrl::Create(wxWindow *parent, return FALSE; } + // the string value overrides the numeric one (for backwards compatibility + // reasons and also because it is simpler to satisfy the string value which + // comes much sooner in the list of arguments and leave the initial + // parameter unspecified) + if ( !value.empty() ) + { + long l; + if ( value.ToLong(&l) ) + initial = l; + } + SetBackgroundColour(*wxRED); m_text = new wxSpinCtrlText(this, value); m_btn = new wxSpinCtrlButton(this, style); m_btn->SetRange(min, max); m_btn->SetValue(initial); - - DoSetSize(pos.x, pos.y, size.x, size.y); #ifdef __WXMAC__ - DoMoveWindow( pos.x, pos.y, size.x, size.y ) ; + wxSize csize = size ; + if ( size.y == -1 ) { + csize.y = m_text->GetSize().y ; + } + DoSetSize(pos.x, pos.y, csize.x, csize.y); +#else + DoSetSize(pos.x, pos.y, size.x, size.y); #endif // have to disable this window to avoid interfering it with message // processing to the text and the button... but pretend it is enabled to @@ -166,8 +192,9 @@ bool wxSpinCtrl::Create(wxWindow *parent, // we don't even need to show this window itself - and not doing it avoids // that it overwrites the text control wxControl::Show(FALSE); +#ifndef __WXMAC__ m_isShown = TRUE; - +#endif return TRUE; } @@ -201,7 +228,11 @@ void wxSpinCtrl::DoMoveWindow(int x, int y, int width, int height) wxCoord wText = width - sizeBtn.x; m_text->SetSize(x, y, wText, height); +#ifdef __WXMAC__ + m_btn->SetSize(x + wText + MARGIN, y, -1, -1); +#else m_btn->SetSize(x + wText + MARGIN, y, -1, height); +#endif } // ---------------------------------------------------------------------------- @@ -323,4 +354,5 @@ void wxSpinCtrl::SetRange(int min, int max) m_btn->SetRange(min, max); } +#endif // wxUSE_SPINCTRL #endif // !wxPort-with-native-spinctrl