2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: stopwatch.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxStopWatch
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxStopWatch
|
|
|
|
@wxheader{stopwatch.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
The wxStopWatch class allow you to measure time intervals. For example, you may
|
|
|
|
use it to measure the time elapsed by some function:
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@code
|
|
|
|
wxStopWatch sw;
|
|
|
|
CallLongRunningFunction();
|
|
|
|
wxLogMessage("The long running function took %ldms to execute",
|
|
|
|
sw.Time());
|
|
|
|
sw.Pause();
|
|
|
|
... stopwatch is stopped now ...
|
|
|
|
sw.Resume();
|
|
|
|
CallLongRunningFunction();
|
|
|
|
wxLogMessage("And calling it twice took $ldms in all", sw.Time());
|
|
|
|
@endcode
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{misc}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxTimer
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
class wxStopWatch
|
2008-03-08 13:52:38 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor. This starts the stop watch.
|
|
|
|
*/
|
|
|
|
wxStopWatch();
|
|
|
|
|
|
|
|
/**
|
2008-03-08 14:43:31 +00:00
|
|
|
Pauses the stop watch. Call Resume() to resume
|
2008-03-08 13:52:38 +00:00
|
|
|
time measuring again.
|
|
|
|
If this method is called several times, @c Resume() must be called the same
|
2008-03-08 14:43:31 +00:00
|
|
|
number of times to really resume the stop watch. You may, however, call
|
2008-03-08 13:52:38 +00:00
|
|
|
Start() to resume it unconditionally.
|
|
|
|
*/
|
|
|
|
void Pause();
|
|
|
|
|
|
|
|
/**
|
2008-03-08 14:43:31 +00:00
|
|
|
Resumes the stop watch which had been paused with
|
2008-03-08 13:52:38 +00:00
|
|
|
Pause().
|
|
|
|
*/
|
|
|
|
void Resume();
|
|
|
|
|
|
|
|
/**
|
|
|
|
(Re)starts the stop watch with a given initial value.
|
|
|
|
*/
|
|
|
|
void Start(long milliseconds = 0);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the time in milliseconds since the start (or restart) or the last call
|
2008-03-08 14:43:31 +00:00
|
|
|
of
|
2008-03-08 13:52:38 +00:00
|
|
|
Pause().
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
long Time() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
// ============================================================================
|
|
|
|
// Global functions/macros
|
|
|
|
// ============================================================================
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of seconds since local time 00:00:00 Jan 1st 1970.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see wxDateTime::Now
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
long wxGetLocalTime();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of seconds since GMT 00:00:00 Jan 1st 1970.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see wxDateTime::Now
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
long wxGetUTCTime();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of milliseconds since local time 00:00:00 Jan 1st 1970.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see wxDateTime::Now, wxLongLong
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxLongLong wxGetLocalTimeMillis();
|
|
|
|
|