closes #15792 git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@75532 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        wx/stopwatch.h
 | |
| // Purpose:     wxStopWatch and global time-related functions
 | |
| // Author:      Julian Smart (wxTimer), Sylvain Bougnoux (wxStopWatch),
 | |
| //              Vadim Zeitlin (time functions, current wxStopWatch)
 | |
| // Created:     26.06.03 (extracted from wx/timer.h)
 | |
| // Copyright:   (c) 1998-2003 Julian Smart, Sylvain Bougnoux
 | |
| //              (c) 2011 Vadim Zeitlin
 | |
| // Licence:     wxWindows licence
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _WX_STOPWATCH_H_
 | |
| #define _WX_STOPWATCH_H_
 | |
| 
 | |
| #include "wx/defs.h"
 | |
| #include "wx/longlong.h"
 | |
| 
 | |
| // Time-related functions are also available via this header for compatibility
 | |
| // but you should include wx/time.h directly if you need only them and not
 | |
| // wxStopWatch itself.
 | |
| #include "wx/time.h"
 | |
| 
 | |
| // ----------------------------------------------------------------------------
 | |
| // wxStopWatch: measure time intervals with up to 1ms resolution
 | |
| // ----------------------------------------------------------------------------
 | |
| 
 | |
| #if wxUSE_STOPWATCH
 | |
| 
 | |
| class WXDLLIMPEXP_BASE wxStopWatch
 | |
| {
 | |
| public:
 | |
|     // ctor starts the stop watch
 | |
|     wxStopWatch() { m_pauseCount = 0; Start(); }
 | |
| 
 | |
|     // Start the stop watch at the moment t0 expressed in milliseconds (i.e.
 | |
|     // calling Time() immediately afterwards returns t0). This can be used to
 | |
|     // restart an existing stopwatch.
 | |
|     void Start(long t0 = 0);
 | |
| 
 | |
|     // pause the stop watch
 | |
|     void Pause()
 | |
|     {
 | |
|         if ( m_pauseCount++ == 0 )
 | |
|             m_elapsedBeforePause = GetCurrentClockValue() - m_t0;
 | |
|     }
 | |
| 
 | |
|     // resume it
 | |
|     void Resume()
 | |
|     {
 | |
|         wxASSERT_MSG( m_pauseCount > 0,
 | |
|                       wxT("Resuming stop watch which is not paused") );
 | |
| 
 | |
|         if ( --m_pauseCount == 0 )
 | |
|         {
 | |
|             DoStart();
 | |
|             m_t0 -= m_elapsedBeforePause;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // Get elapsed time since the last Start() in microseconds.
 | |
|     wxLongLong TimeInMicro() const;
 | |
| 
 | |
|     // get elapsed time since the last Start() in milliseconds
 | |
|     long Time() const { return (TimeInMicro()/1000).ToLong(); }
 | |
| 
 | |
| private:
 | |
|     // Really starts the stop watch. The initial time is set to current clock
 | |
|     // value.
 | |
|     void DoStart();
 | |
| 
 | |
|     // Returns the current clock value in its native units.
 | |
|     wxLongLong GetCurrentClockValue() const;
 | |
| 
 | |
|     // Return the frequency of the clock used in its ticks per second.
 | |
|     wxLongLong GetClockFreq() const;
 | |
| 
 | |
| 
 | |
|     // The clock value when the stop watch was last started. Its units vary
 | |
|     // depending on the platform.
 | |
|     wxLongLong m_t0;
 | |
| 
 | |
|     // The elapsed time as of last Pause() call (only valid if m_pauseCount >
 | |
|     // 0) in the same units as m_t0.
 | |
|     wxLongLong m_elapsedBeforePause;
 | |
| 
 | |
|     // if > 0, the stop watch is paused, otherwise it is running
 | |
|     int m_pauseCount;
 | |
| };
 | |
| 
 | |
| #endif // wxUSE_STOPWATCH
 | |
| 
 | |
| #endif // _WX_STOPWATCH_H_
 |