// Created: 01/02/97
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_TIMER_H_
#define _WX_TIMER_H_
-#ifdef __GNUG__
-#pragma interface "timer.h"
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
+ #pragma interface "timer.h"
#endif
-#include "wx/object.h"
-
-class WXDLLEXPORT wxTimer: public wxObject
+class WXDLLEXPORT wxTimer : public wxTimerBase
{
- DECLARE_DYNAMIC_CLASS(wxTimer)
-
- public:
- bool oneShot ;
- int milli ;
- int lastMilli ;
-
- long id;
- public:
- wxTimer(void);
- ~wxTimer(void);
- virtual bool Start(int milliseconds = -1,bool one_shot = FALSE); // Start timer
- virtual void Stop(void); // Stop timer
- virtual void Notify(void) = 0; // Override this member
- inline int Interval(void) { return milli ; }; // Returns the current interval time (0 if stop)
-};
+friend void wxProcessTimer(wxTimer& timer);
+
+public:
+ wxTimer() { Init(); }
+ wxTimer(wxEvtHandler *owner, int id = -1) : wxTimerBase(owner, id)
+ { Init(); }
+ ~wxTimer();
-// Timer functions (milliseconds)
-void WXDLLEXPORT wxStartTimer(void);
-// Gets time since last wxStartTimer or wxGetElapsedTime
-long WXDLLEXPORT wxGetElapsedTime(bool resetTimer = TRUE);
+ virtual bool Start(int milliseconds = -1, bool oneShot = FALSE);
+ virtual void Stop();
-// EXPERIMENTAL: comment this out if it doesn't compile.
-bool WXDLLEXPORT wxGetLocalTime(long *timeZone, int *dstObserved);
+ virtual bool IsRunning() const { return m_id != 0; }
-// Get number of seconds since 00:00:00 GMT, Jan 1st 1970.
-long WXDLLEXPORT wxGetCurrentTime(void);
+protected:
+ void Init();
+
+ unsigned long m_id;
+
+private:
+ DECLARE_DYNAMIC_CLASS_NO_COPY(wxTimer)
+};
#endif
// _WX_TIMERH_