X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/21fd55291b631eae9ccfd78866616aca6e573ebe..62f864c32c53356b7228591c85b14abc491c46f0:/src/mac/carbon/gauge.cpp diff --git a/src/mac/carbon/gauge.cpp b/src/mac/carbon/gauge.cpp index bfdbe410dc..3bfb3e2439 100644 --- a/src/mac/carbon/gauge.cpp +++ b/src/mac/carbon/gauge.cpp @@ -9,15 +9,17 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "gauge.h" #endif +#include "wx/wxprec.h" + +#if wxUSE_GAUGE + #include "wx/gauge.h" -#if !USE_SHARED_LIBRARY IMPLEMENT_DYNAMIC_CLASS(wxGauge, wxControl) -#endif #include "wx/mac/uma.h" @@ -35,18 +37,20 @@ bool wxGauge::Create(wxWindow *parent, wxWindowID id, return false; wxSize size = s ; - - if ( size.x == wxDefaultSize.x && size.y == wxDefaultSize.y) + /* + if ( size.x == wxDefaultCoord && size.y == wxDefaultCoord) { size = wxSize( 200 , 16 ) ; } - + */ Rect bounds = wxMacGetBoundsForControl( this , pos , size ) ; - m_peer = new wxMacControl() ; + m_peer = new wxMacControl(this) ; verify_noerr ( CreateProgressBarControl( MAC_WXHWND(parent->MacGetTopLevelWindowRef()) , &bounds , - GetValue() , 0 , GetRange() , false /* not indeterminate */ , *m_peer ) ); - - + GetValue() , 0 , GetRange() , false /* not indeterminate */ , m_peer->GetControlRefAddr() ) ); + + if ( GetValue() == 0 ) + m_peer->SetData( kControlEntireControl , kControlProgressBarAnimatingTag , (Boolean) false ) ; + MacPostControlCreate(pos,size) ; return TRUE; @@ -67,7 +71,19 @@ void wxGauge::SetValue(int pos) // some change behind the values by it wxGaugeBase::SetValue(pos) ; if ( m_peer && m_peer->Ok() ) + { m_peer->SetValue( GetValue() ) ; + // we turn off animation in the unnecessary situations as this is eating a lot of CPU otherwise + Boolean shouldAnimate = ( GetValue() > 0 && GetValue() < GetRange() ) ; + if ( m_peer->GetData( kControlEntireControl , kControlProgressBarAnimatingTag ) != shouldAnimate ) + { + m_peer->SetData( kControlEntireControl , kControlProgressBarAnimatingTag , shouldAnimate ) ; + if ( !shouldAnimate ) + { + Refresh() ; + } + } + } } int wxGauge::GetValue() const @@ -79,3 +95,5 @@ int wxGauge::GetValue() const return m_gaugePos ; } +#endif // wxUSE_GAUGE +