X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ed7919869508ccd5c868683c28706f82e82a1b9b..52f96deca1baa3c5ac50eb1c22481ae21cb941fc:/include/wx/timer.h diff --git a/include/wx/timer.h b/include/wx/timer.h index 30e48fca44..51432d1610 100644 --- a/include/wx/timer.h +++ b/include/wx/timer.h @@ -22,6 +22,8 @@ #include "wx/longlong.h" #include "wx/event.h" +#if wxUSE_GUI + // ---------------------------------------------------------------------------- // wxTimer // ---------------------------------------------------------------------------- @@ -41,29 +43,25 @@ public: // class: the owner will get timer notifications which can be handled with // EVT_TIMER wxTimerBase(wxEvtHandler *owner, int id = -1) - { Init(); SetOwner(owner, -1); } + { Init(); SetOwner(owner, id); } // same as ctor above void SetOwner(wxEvtHandler *owner, int id = -1) { m_owner = owner; m_idTimer = id; } +#ifdef __WXMAC_X__ + virtual ~wxTimerBase() {} // Added min for Mac X +#endif + // working with the timer // ---------------------- // start the timer: if milliseconds == -1, use the same value as for the // last Start() - virtual bool Start(int milliseconds = -1, bool oneShot = FALSE) - { - if ( milliseconds != -1 ) - { - m_milli = milliseconds; - } - - m_oneShot = oneShot; - - return TRUE; - } - + // + // it is now valid to call Start() multiple times: this just restarts the + // timer if it is already running + virtual bool Start(int milliseconds = -1, bool oneShot = FALSE); // stop the timer virtual void Stop() = 0; @@ -121,6 +119,37 @@ protected: #include "wx/stubs/timer.h" #endif +// ---------------------------------------------------------------------------- +// wxTimerRunner: starts the timer in its ctor, stops in the dtor +// ---------------------------------------------------------------------------- + +class WXDLLEXPORT wxTimerRunner +{ +public: + wxTimerRunner(wxTimer& timer) : m_timer(timer) { } + wxTimerRunner(wxTimer& timer, int milli, bool oneShot = FALSE) + : m_timer(timer) + { + m_timer.Start(milli, oneShot); + } + + void Start(int milli, bool oneShot = FALSE) + { + m_timer.Start(milli, oneShot); + } + + ~wxTimerRunner() + { + if ( m_timer.IsRunning() ) + { + m_timer.Stop(); + } + } + +private: + wxTimer& m_timer; +}; + // ---------------------------------------------------------------------------- // wxTimerEvent // ---------------------------------------------------------------------------- @@ -146,7 +175,10 @@ private: typedef void (wxEvtHandler::*wxTimerEventFunction)(wxTimerEvent&); -#define EVT_TIMER(id, func) { wxEVT_TIMER, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTimerEventFunction) & func, NULL}, +#define EVT_TIMER(id, func) \ + DECLARE_EVENT_TABLE_ENTRY( wxEVT_TIMER, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTimerEventFunction) & func, NULL), + +#endif // wxUSE_GUI // ---------------------------------------------------------------------------- // wxStopWatch: measure time intervals with up to 1ms resolution @@ -158,8 +190,8 @@ public: // ctor starts the stop watch wxStopWatch() { Start(); } void Start(long t = 0); - inline void Pause() { m_pause = GetElapsedTime(); } - inline void Resume() { Start(m_pause); } + void Pause() { m_pause = GetElapsedTime(); } + void Resume() { Start(m_pause); } // get elapsed time since the last Start() or Pause() in milliseconds long Time() const; @@ -187,10 +219,13 @@ long WXDLLEXPORT wxGetElapsedTime(bool resetTimer = TRUE); // ---------------------------------------------------------------------------- // Get number of seconds since local time 00:00:00 Jan 1st 1970. -long WXDLLEXPORT wxGetLocalTime(); +extern long WXDLLEXPORT wxGetLocalTime(); // Get number of seconds since GMT 00:00:00, Jan 1st 1970. -long WXDLLEXPORT wxGetUTCTime(); +extern long WXDLLEXPORT wxGetUTCTime(); + +// Get number of milliseconds since local time 00:00:00 Jan 1st 1970 +extern wxLongLong WXDLLEXPORT wxGetLocalTimeMillis(); #define wxGetCurrentTime() wxGetLocalTime()