X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/217099990c2665d18d352c60058106da9a014ab8..dcf0fce44b34522ee1d3bef16a42b36cfd3c4bde:/src/generic/spinctlg.cpp?ds=sidebyside diff --git a/src/generic/spinctlg.cpp b/src/generic/spinctlg.cpp index 439e8987d2..5c02451b72 100644 --- a/src/generic/spinctlg.cpp +++ b/src/generic/spinctlg.cpp @@ -28,9 +28,8 @@ #pragma hdrstop #endif -#if !wxUSE_SPINBTN - #error "This file can only be compiled if wxSpinButton is available" -#endif // !wxUSE_SPINBTN +#if !(defined(__WXMSW__) || defined(__WXGTK__) || defined(__WXPM__)) || defined(__WXMAC__) || \ + defined(__WXUNIVERSAL__) #ifndef WX_PRECOMP #include "wx/textctrl.h" @@ -148,7 +147,6 @@ bool wxSpinCtrl::Create(wxWindow *parent, } SetBackgroundColour(*wxRED); - m_text = new wxSpinCtrlText(this, value); m_btn = new wxSpinCtrlButton(this, style); @@ -156,7 +154,9 @@ bool wxSpinCtrl::Create(wxWindow *parent, m_btn->SetValue(initial); DoSetSize(pos.x, pos.y, size.x, size.y); - +#ifdef __WXMAC__ + DoMoveWindow( 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 // make IsEnabled() return TRUE @@ -197,8 +197,7 @@ void wxSpinCtrl::DoMoveWindow(int x, int y, int width, int height) wxControl::DoMoveWindow(x, y, width, height); // position the subcontrols inside the client area - wxSize sizeBtn = m_btn->GetSize(), - sizeText = m_text->GetSize(); + wxSize sizeBtn = m_btn->GetSize(); wxCoord wText = width - sizeBtn.x; m_text->SetSize(x, y, wText, height); @@ -225,8 +224,13 @@ bool wxSpinCtrl::Show(bool show) if ( !wxControl::Show(show) ) return FALSE; - m_btn->Show(show); - m_text->Show(show); + // under GTK Show() is called the first time before we are fully + // constructed + if ( m_btn ) + { + m_btn->Show(show); + m_text->Show(show); + } return TRUE; } @@ -319,3 +323,4 @@ void wxSpinCtrl::SetRange(int min, int max) m_btn->SetRange(min, max); } +#endif // !wxPort-with-native-spinctrl