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:
@@ -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
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -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
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
Reference in New Issue
Block a user