2003-06-25 23:49:45 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/stopwatch.h
|
|
|
|
// Purpose: wxStopWatch and global time-related functions
|
2011-11-27 19:50:23 +00:00
|
|
|
// Author: Julian Smart (wxTimer), Sylvain Bougnoux (wxStopWatch),
|
|
|
|
// Vadim Zeitlin (time functions, current wxStopWatch)
|
2003-06-25 23:49:45 +00:00
|
|
|
// Created: 26.06.03 (extracted from wx/timer.h)
|
2005-05-04 18:57:50 +00:00
|
|
|
// Copyright: (c) 1998-2003 Julian Smart, Sylvain Bougnoux
|
2011-11-27 19:50:23 +00:00
|
|
|
// (c) 2011 Vadim Zeitlin
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2003-06-25 23:49:45 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_STOPWATCH_H_
|
|
|
|
#define _WX_STOPWATCH_H_
|
2003-08-14 18:20:51 +00:00
|
|
|
|
2005-03-16 16:18:31 +00:00
|
|
|
#include "wx/defs.h"
|
2003-08-14 18:20:51 +00:00
|
|
|
#include "wx/longlong.h"
|
|
|
|
|
2011-11-27 19:50:23 +00:00
|
|
|
// 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"
|
|
|
|
|
2003-06-25 23:49:45 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxStopWatch: measure time intervals with up to 1ms resolution
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#if wxUSE_STOPWATCH
|
|
|
|
|
2003-07-02 01:59:24 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxStopWatch
|
2003-06-25 23:49:45 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// ctor starts the stop watch
|
|
|
|
wxStopWatch() { m_pauseCount = 0; Start(); }
|
|
|
|
|
2011-11-27 19:50:12 +00:00
|
|
|
// 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.
|
2003-06-25 23:49:45 +00:00
|
|
|
void Start(long t0 = 0);
|
|
|
|
|
|
|
|
// pause the stop watch
|
|
|
|
void Pause()
|
|
|
|
{
|
2006-08-16 12:17:05 +00:00
|
|
|
if ( m_pauseCount++ == 0 )
|
2011-11-27 19:50:12 +00:00
|
|
|
m_elapsedBeforePause = GetCurrentClockValue() - m_t0;
|
2003-06-25 23:49:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// resume it
|
|
|
|
void Resume()
|
|
|
|
{
|
|
|
|
wxASSERT_MSG( m_pauseCount > 0,
|
2009-07-23 20:30:22 +00:00
|
|
|
wxT("Resuming stop watch which is not paused") );
|
2003-06-25 23:49:45 +00:00
|
|
|
|
2006-08-16 12:17:05 +00:00
|
|
|
if ( --m_pauseCount == 0 )
|
2011-11-27 19:50:12 +00:00
|
|
|
{
|
|
|
|
DoStart();
|
|
|
|
m_t0 -= m_elapsedBeforePause;
|
|
|
|
}
|
2003-06-25 23:49:45 +00:00
|
|
|
}
|
|
|
|
|
2011-11-27 19:50:12 +00:00
|
|
|
// Get elapsed time since the last Start() in microseconds.
|
|
|
|
wxLongLong TimeInMicro() const;
|
2003-06-25 23:49:45 +00:00
|
|
|
|
2011-11-27 19:50:12 +00:00
|
|
|
// get elapsed time since the last Start() in milliseconds
|
|
|
|
long Time() const { return (TimeInMicro()/1000).ToLong(); }
|
2003-06-25 23:49:45 +00:00
|
|
|
|
|
|
|
private:
|
2011-11-27 19:50:12 +00:00
|
|
|
// 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.
|
2003-06-25 23:49:45 +00:00
|
|
|
wxLongLong m_t0;
|
|
|
|
|
2011-11-27 19:50:12 +00:00
|
|
|
// The elapsed time as of last Pause() call (only valid if m_pauseCount >
|
|
|
|
// 0) in the same units as m_t0.
|
|
|
|
wxLongLong m_elapsedBeforePause;
|
2003-06-25 23:49:45 +00:00
|
|
|
|
|
|
|
// if > 0, the stop watch is paused, otherwise it is running
|
|
|
|
int m_pauseCount;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // wxUSE_STOPWATCH
|
|
|
|
|
|
|
|
#endif // _WX_STOPWATCH_H_
|