common value changed code for spinbutton

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@15504 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Stefan Csomor
2002-05-11 06:53:56 +00:00
parent 7595f3811e
commit a54b0880d6
2 changed files with 102 additions and 78 deletions

View File

@@ -83,7 +83,7 @@ int wxSpinButton::GetValue() const
void wxSpinButton::SetValue(int val) void wxSpinButton::SetValue(int val)
{ {
m_value = val ; MacHandleValueChanged( val - m_value ) ;
} }
void wxSpinButton::SetRange(int minVal, int maxVal) void wxSpinButton::SetRange(int minVal, int maxVal)
@@ -94,55 +94,47 @@ void wxSpinButton::SetRange(int minVal, int maxVal)
SetControlMinimum((ControlHandle) m_macControl , minVal ) ; SetControlMinimum((ControlHandle) m_macControl , minVal ) ;
} }
void wxSpinButton::MacHandleControlClick( WXWidget control , wxInt16 controlpart ) void wxSpinButton::MacHandleValueChanged( int inc )
{ {
if ( (ControlHandle) m_macControl == NULL )
return ;
wxEventType scrollEvent = wxEVT_NULL;
int oldValue = m_value ; int oldValue = m_value ;
wxEventType scrollEvent = wxEVT_NULL;
int nScrollInc = 0;
switch( controlpart ) m_value = oldValue + inc;
{
case kControlUpButtonPart :
nScrollInc = 1;
scrollEvent = wxEVT_SCROLL_LINEUP;
break ;
case kControlDownButtonPart :
nScrollInc = -1;
scrollEvent = wxEVT_SCROLL_LINEDOWN;
break ;
}
m_value = m_value + nScrollInc; if (m_value < m_min)
{
if (m_value < m_min) if ( m_windowStyle & wxSP_WRAP )
{
if ( m_windowStyle & wxSP_WRAP )
m_value = m_max; m_value = m_max;
else else
m_value = m_min; m_value = m_min;
} }
if (m_value > m_max) if (m_value > m_max)
{ {
if ( m_windowStyle & wxSP_WRAP ) if ( m_windowStyle & wxSP_WRAP )
m_value = m_min; m_value = m_min;
else else
m_value = m_max; m_value = m_max;
} }
wxSpinEvent event(scrollEvent, m_windowId); if ( oldValue - m_value == -1 )
scrollEvent = wxEVT_SCROLL_LINEDOWN ;
else if ( oldValue - m_value == 1 )
scrollEvent = wxEVT_SCROLL_LINEUP ;
else
scrollEvent = wxEVT_SCROLL_THUMBTRACK ;
event.SetPosition(m_value); wxSpinEvent event(scrollEvent, m_windowId);
event.SetEventObject( this );
if ((GetEventHandler()->ProcessEvent( event )) && event.SetPosition(m_value);
event.SetEventObject( this );
if ((GetEventHandler()->ProcessEvent( event )) &&
!event.IsAllowed() ) !event.IsAllowed() )
{ {
m_value = oldValue ; m_value = oldValue ;
} }
SetControlValue( (ControlHandle) m_macControl , m_value ) ; SetControlValue( (ControlHandle) m_macControl , m_value ) ;
/* always send a thumbtrack event */ /* always send a thumbtrack event */
if (scrollEvent != wxEVT_SCROLL_THUMBTRACK) if (scrollEvent != wxEVT_SCROLL_THUMBTRACK)
@@ -155,6 +147,26 @@ void wxSpinButton::MacHandleControlClick( WXWidget control , wxInt16 controlpart
} }
} }
void wxSpinButton::MacHandleControlClick( WXWidget control , wxInt16 controlpart )
{
if ( (ControlHandle) m_macControl == NULL )
return ;
int nScrollInc = 0;
switch( controlpart )
{
case kControlUpButtonPart :
nScrollInc = 1;
break ;
case kControlDownButtonPart :
nScrollInc = -1;
break ;
}
MacHandleValueChanged( nScrollInc ) ;
}
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// size calculation // size calculation
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------

View File

@@ -83,7 +83,7 @@ int wxSpinButton::GetValue() const
void wxSpinButton::SetValue(int val) void wxSpinButton::SetValue(int val)
{ {
m_value = val ; MacHandleValueChanged( val - m_value ) ;
} }
void wxSpinButton::SetRange(int minVal, int maxVal) void wxSpinButton::SetRange(int minVal, int maxVal)
@@ -94,55 +94,47 @@ void wxSpinButton::SetRange(int minVal, int maxVal)
SetControlMinimum((ControlHandle) m_macControl , minVal ) ; SetControlMinimum((ControlHandle) m_macControl , minVal ) ;
} }
void wxSpinButton::MacHandleControlClick( WXWidget control , wxInt16 controlpart ) void wxSpinButton::MacHandleValueChanged( int inc )
{ {
if ( (ControlHandle) m_macControl == NULL )
return ;
wxEventType scrollEvent = wxEVT_NULL;
int oldValue = m_value ; int oldValue = m_value ;
wxEventType scrollEvent = wxEVT_NULL;
int nScrollInc = 0;
switch( controlpart ) m_value = oldValue + inc;
{
case kControlUpButtonPart :
nScrollInc = 1;
scrollEvent = wxEVT_SCROLL_LINEUP;
break ;
case kControlDownButtonPart :
nScrollInc = -1;
scrollEvent = wxEVT_SCROLL_LINEDOWN;
break ;
}
m_value = m_value + nScrollInc; if (m_value < m_min)
{
if (m_value < m_min) if ( m_windowStyle & wxSP_WRAP )
{
if ( m_windowStyle & wxSP_WRAP )
m_value = m_max; m_value = m_max;
else else
m_value = m_min; m_value = m_min;
} }
if (m_value > m_max) if (m_value > m_max)
{ {
if ( m_windowStyle & wxSP_WRAP ) if ( m_windowStyle & wxSP_WRAP )
m_value = m_min; m_value = m_min;
else else
m_value = m_max; m_value = m_max;
} }
wxSpinEvent event(scrollEvent, m_windowId); if ( oldValue - m_value == -1 )
scrollEvent = wxEVT_SCROLL_LINEDOWN ;
else if ( oldValue - m_value == 1 )
scrollEvent = wxEVT_SCROLL_LINEUP ;
else
scrollEvent = wxEVT_SCROLL_THUMBTRACK ;
event.SetPosition(m_value); wxSpinEvent event(scrollEvent, m_windowId);
event.SetEventObject( this );
if ((GetEventHandler()->ProcessEvent( event )) && event.SetPosition(m_value);
event.SetEventObject( this );
if ((GetEventHandler()->ProcessEvent( event )) &&
!event.IsAllowed() ) !event.IsAllowed() )
{ {
m_value = oldValue ; m_value = oldValue ;
} }
SetControlValue( (ControlHandle) m_macControl , m_value ) ; SetControlValue( (ControlHandle) m_macControl , m_value ) ;
/* always send a thumbtrack event */ /* always send a thumbtrack event */
if (scrollEvent != wxEVT_SCROLL_THUMBTRACK) if (scrollEvent != wxEVT_SCROLL_THUMBTRACK)
@@ -155,6 +147,26 @@ void wxSpinButton::MacHandleControlClick( WXWidget control , wxInt16 controlpart
} }
} }
void wxSpinButton::MacHandleControlClick( WXWidget control , wxInt16 controlpart )
{
if ( (ControlHandle) m_macControl == NULL )
return ;
int nScrollInc = 0;
switch( controlpart )
{
case kControlUpButtonPart :
nScrollInc = 1;
break ;
case kControlDownButtonPart :
nScrollInc = -1;
break ;
}
MacHandleValueChanged( nScrollInc ) ;
}
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// size calculation // size calculation
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------