// Sync the textctrl since the user expects that the button will modify
// what they see in the textctrl.
- SyncSpinToText();
+ SyncSpinToText(SendEvent_None);
int spin_value = event.GetPosition();
double step = (event.GetEventType() == wxEVT_SCROLL_LINEUP) ? 1 : -1;
m_spin_value = spin_value;
- if ( DoSetValue(value) )
+ // Notify about the change in wxTextCtrl too.
+ if ( DoSetValue(value, SendEvent_Text) )
DoSendEvent();
}
void wxSpinCtrlGenericBase::OnTextLostFocus(wxFocusEvent& event)
{
- SyncSpinToText();
+ SyncSpinToText(SendEvent_Text);
DoSendEvent();
event.Skip();
value = AdjustToFitInRange(value);
- SyncSpinToText();
+ SyncSpinToText(SendEvent_None);
- if ( DoSetValue(value) )
+ // No need to send event, it was already generated by wxTextCtrl itself.
+ if ( DoSetValue(value, SendEvent_None) )
DoSendEvent();
}
// Textctrl functions
// ----------------------------------------------------------------------------
-bool wxSpinCtrlGenericBase::SyncSpinToText()
+bool wxSpinCtrlGenericBase::SyncSpinToText(SendEvent sendEvent)
{
if ( !m_textCtrl || !m_textCtrl->IsModified() )
return false;
// we must always set the value here, even if it's equal to m_value, as
// otherwise we could be left with an out of range value when leaving the
// text control and the current value is already m_max for example
- return DoSetValue(textValue);
+ return DoSetValue(textValue, sendEvent);
}
// ----------------------------------------------------------------------------
double val;
if ( DoTextToValue(text, &val) && InRange(val) )
{
- DoSetValue(val);
+ DoSetValue(val, SendEvent_None);
}
else // not a number at all or out of range
{
- m_textCtrl->SetValue(text);
+ m_textCtrl->ChangeValue(text);
m_textCtrl->SelectAll();
}
}
-bool wxSpinCtrlGenericBase::DoSetValue(double val)
+bool wxSpinCtrlGenericBase::DoSetValue(double val, SendEvent sendEvent)
{
wxCHECK_MSG( m_textCtrl, false, wxT("invalid call to wxSpinCtrl::SetValue") );
{
if ( !DoTextToValue(str, &m_value ) ) // wysiwyg for textctrl
m_value = val;
- m_textCtrl->SetValue( str );
+
+ switch ( sendEvent )
+ {
+ case SendEvent_None:
+ m_textCtrl->ChangeValue(str);
+ break;
+
+ case SendEvent_Text:
+ m_textCtrl->SetValue(str);
+ break;
+ }
+
m_textCtrl->SelectAll();
m_textCtrl->DiscardEdits();
return true;
{
m_min = min;
if ( m_value < m_min )
- DoSetValue(m_min);
+ DoSetValue(m_min, SendEvent_None);
m_max = max;
if ( m_value > m_max )
- DoSetValue(m_max);
+ DoSetValue(m_max, SendEvent_None);
}
void wxSpinCtrlGenericBase::DoSetIncrement(double inc)
void wxSpinCtrlGenericBase::SetSnapToTicks(bool snap_to_ticks)
{
m_snap_to_ticks = snap_to_ticks;
- DoSetValue(m_value);
+ DoSetValue(m_value, SendEvent_None);
}
void wxSpinCtrlGenericBase::SetSelection(long from, long to)
// ... but DoValueToText() after doing it.
if ( hasValidVal )
- m_textCtrl->SetValue(DoValueToText(val));
+ m_textCtrl->ChangeValue(DoValueToText(val));
return true;
}
m_format.Printf(wxT("%%0.%ulf"), digits);
- DoSetValue(m_value);
+ DoSetValue(m_value, SendEvent_None);
}
#endif // wxUSE_SPINBTN