From: Stefan Csomor Date: Tue, 1 May 2001 06:46:38 +0000 (+0000) Subject: corrected event handling according to current msw/gtk implementation X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/72d750d4620a438af0c0233712622af2e28bad1d?ds=inline corrected event handling according to current msw/gtk implementation git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@9951 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/src/mac/carbon/spinbutt.cpp b/src/mac/carbon/spinbutt.cpp index fc9954f9e5..4003a1a388 100644 --- a/src/mac/carbon/spinbutt.cpp +++ b/src/mac/carbon/spinbutt.cpp @@ -95,6 +95,8 @@ void wxSpinButton::SetRange(int minVal, int maxVal) { m_min = minVal; m_max = maxVal; + SetControlMaximum( m_macControl , maxVal ) ; + SetControlMinimum( m_macControl , minVal ) ; } void wxSpinButton::MacHandleControlClick( ControlHandle control , SInt16 controlpart ) @@ -102,6 +104,7 @@ void wxSpinButton::MacHandleControlClick( ControlHandle control , SInt16 control if ( m_macControl == NULL ) return ; + int oldValue = m_value ; wxEventType scrollEvent = wxEVT_NULL; int nScrollInc = 0; @@ -135,11 +138,26 @@ void wxSpinButton::MacHandleControlClick( ControlHandle control , SInt16 control m_value = m_max; } - wxScrollEvent event(scrollEvent, m_windowId); + wxSpinEvent event(scrollEvent, m_windowId); event.SetPosition(m_value); event.SetEventObject( this ); - GetEventHandler()->ProcessEvent(event); + if ((GetEventHandler()->ProcessEvent( event )) && + !event.IsAllowed() ) + { + m_value = oldValue ; + } + SetControlValue( m_macControl , m_value ) ; + + /* always send a thumbtrack event */ + if (scrollEvent != wxEVT_SCROLL_THUMBTRACK) + { + scrollEvent = wxEVT_SCROLL_THUMBTRACK; + wxSpinEvent event2( scrollEvent, GetId()); + event2.SetPosition( m_value ); + event2.SetEventObject( this ); + GetEventHandler()->ProcessEvent( event2 ); + } } // ---------------------------------------------------------------------------- diff --git a/src/mac/spinbutt.cpp b/src/mac/spinbutt.cpp index fc9954f9e5..4003a1a388 100644 --- a/src/mac/spinbutt.cpp +++ b/src/mac/spinbutt.cpp @@ -95,6 +95,8 @@ void wxSpinButton::SetRange(int minVal, int maxVal) { m_min = minVal; m_max = maxVal; + SetControlMaximum( m_macControl , maxVal ) ; + SetControlMinimum( m_macControl , minVal ) ; } void wxSpinButton::MacHandleControlClick( ControlHandle control , SInt16 controlpart ) @@ -102,6 +104,7 @@ void wxSpinButton::MacHandleControlClick( ControlHandle control , SInt16 control if ( m_macControl == NULL ) return ; + int oldValue = m_value ; wxEventType scrollEvent = wxEVT_NULL; int nScrollInc = 0; @@ -135,11 +138,26 @@ void wxSpinButton::MacHandleControlClick( ControlHandle control , SInt16 control m_value = m_max; } - wxScrollEvent event(scrollEvent, m_windowId); + wxSpinEvent event(scrollEvent, m_windowId); event.SetPosition(m_value); event.SetEventObject( this ); - GetEventHandler()->ProcessEvent(event); + if ((GetEventHandler()->ProcessEvent( event )) && + !event.IsAllowed() ) + { + m_value = oldValue ; + } + SetControlValue( m_macControl , m_value ) ; + + /* always send a thumbtrack event */ + if (scrollEvent != wxEVT_SCROLL_THUMBTRACK) + { + scrollEvent = wxEVT_SCROLL_THUMBTRACK; + wxSpinEvent event2( scrollEvent, GetId()); + event2.SetPosition( m_value ); + event2.SetEventObject( this ); + GetEventHandler()->ProcessEvent( event2 ); + } } // ----------------------------------------------------------------------------