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;
{
m_spin = spin;
- SetWindowStyle(style);
+ SetWindowStyle(style | wxSP_VERTICAL);
}
protected:
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
// 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;
}