// Author: Vadim Zeitlin
// Modified by:
// Created: 29.01.01
-// RCS-ID: $Id$
// Copyright: (c) 2001 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
// Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////////
if ( DoTextToValue(value, &d) )
{
m_value = d;
- m_textCtrl->SetValue(DoValueToText(m_value));
+ m_textCtrl->ChangeValue(DoValueToText(m_value));
}
}
wxSize tsize(xlen + sizeBtn.x + MARGIN, totalS.y);
#if defined(__WXMSW__)
- tsize.IncBy(0.4 * totalS.y + 4, 0);
+ tsize.IncBy(4*totalS.y/10 + 4, 0);
#elif defined(__WXGTK__)
tsize.IncBy(totalS.y + 10, 0);
#endif // MSW GTK
// 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 (!InRange(val))
- return false;
-
+ if ( val < m_min )
+ val = m_min;
+ if ( val > m_max )
+ val = m_max;
+
if ( m_snap_to_ticks && (m_increment != 0) )
{
double snap_value = val / m_increment;
{
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;
void wxSpinCtrlGenericBase::DoSetRange(double min, double max)
{
m_min = min;
+ if ( m_value < m_min )
+ DoSetValue(m_min, SendEvent_None);
m_max = max;
+ if ( m_value > 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