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_
 |