1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxTimer, wxStopWatch and global time-related functions 
   4 // Author:      Julian Smart (wxTimer), Sylvain Bougnoux (wxStopWatch) 
   5 // Modified by: Vadim Zeitlin (wxTimerBase) 
   6 //              Guillermo Rodriguez (global clean up) 
   9 // Copyright:   (c) wxWidgets team 
  10 // Licence:     wxWindows licence 
  11 ///////////////////////////////////////////////////////////////////////////// 
  13 #ifndef _WX_TIMER_H_BASE_ 
  14 #define _WX_TIMER_H_BASE_ 
  16 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) 
  17     #pragma interface "timerbase.h" 
  22 #if wxUSE_GUI && wxUSE_TIMER 
  24 #include "wx/object.h" 
  25 #include "wx/longlong.h" 
  27 #include "wx/stopwatch.h" // for backwards compatibility 
  29 // ---------------------------------------------------------------------------- 
  31 // ---------------------------------------------------------------------------- 
  33 // more readable flags for Start(): 
  35 // generate notifications periodically until the timer is stopped (default) 
  36 #define wxTIMER_CONTINUOUS false 
  38 // only send the notification once and then stop the timer 
  39 #define wxTIMER_ONE_SHOT true 
  41 // the interface of wxTimer class 
  42 class WXDLLEXPORT wxTimerBase 
: public wxEvtHandler
 
  45     // ctors and initializers 
  46     // ---------------------- 
  48     // default: if you don't call SetOwner(), your only chance to get timer 
  49     // notifications is to override Notify() in the derived class 
  50     wxTimerBase() { Init(); SetOwner(this); } 
  52     // ctor which allows to avoid having to override Notify() in the derived 
  53     // class: the owner will get timer notifications which can be handled with 
  55     wxTimerBase(wxEvtHandler 
*owner
, int timerid 
= wxID_ANY
) 
  56         { Init(); SetOwner(owner
, timerid
); } 
  59     void SetOwner(wxEvtHandler 
*owner
, int timerid 
= wxID_ANY
) 
  60         { m_owner 
= owner
; m_idTimer 
= timerid
; } 
  61     wxEvtHandler
* GetOwner() const { return m_owner
; } 
  63     virtual ~wxTimerBase(); 
  65     // working with the timer 
  66     // ---------------------- 
  68     // start the timer: if milliseconds == -1, use the same value as for the 
  71     // it is now valid to call Start() multiple times: this just restarts the 
  72     // timer if it is already running 
  73     virtual bool Start(int milliseconds 
= -1, bool oneShot 
= false); 
  76     virtual void Stop() = 0; 
  78     // override this in your wxTimer-derived class if you want to process timer 
  79     // messages in it, use non default ctor or SetOwner() otherwise 
  80     virtual void Notify(); 
  85     // return true if the timer is running 
  86     virtual bool IsRunning() const = 0; 
  88     // get the (last) timer interval in the milliseconds 
  89     int GetInterval() const { return m_milli
; } 
  91     // return true if the timer is one shot 
  92     bool IsOneShot() const { return m_oneShot
; } 
  94     // return the timer ID 
  95     int GetId() const { return m_idTimer
; } 
  99     // common part of all ctors 
 100     void Init() { m_oneShot 
= false; m_milli 
= 0; } 
 102     wxEvtHandler 
*m_owner
; 
 105     int     m_milli
;        // the timer interval 
 106     bool    m_oneShot
;      // true if one shot 
 108     DECLARE_NO_COPY_CLASS(wxTimerBase
) 
 111 // ---------------------------------------------------------------------------- 
 113 // ---------------------------------------------------------------------------- 
 115 #if defined(__WXMSW__) 
 116     #include "wx/msw/timer.h" 
 117 #elif defined(__WXMOTIF__) 
 118     #include "wx/motif/timer.h" 
 119 #elif defined(__WXGTK__) 
 120     #include "wx/gtk/timer.h" 
 121 #elif defined(__WXX11__) || defined(__WXMGL__) 
 122     #include "wx/generic/timer.h" 
 123 #elif defined (__WXCOCOA__) 
 124     #include "wx/cocoa/timer.h" 
 125 #elif defined(__WXMAC__) 
 126     #include "wx/mac/timer.h" 
 127 #elif defined(__WXPM__) 
 128     #include "wx/os2/timer.h" 
 131 // ---------------------------------------------------------------------------- 
 132 // wxTimerRunner: starts the timer in its ctor, stops in the dtor 
 133 // ---------------------------------------------------------------------------- 
 135 class WXDLLEXPORT wxTimerRunner
 
 138     wxTimerRunner(wxTimer
& timer
) : m_timer(timer
) { } 
 139     wxTimerRunner(wxTimer
& timer
, int milli
, bool oneShot 
= false) 
 142         m_timer
.Start(milli
, oneShot
); 
 145     void Start(int milli
, bool oneShot 
= false) 
 147         m_timer
.Start(milli
, oneShot
); 
 152         if ( m_timer
.IsRunning() ) 
 161     DECLARE_NO_COPY_CLASS(wxTimerRunner
) 
 164 // ---------------------------------------------------------------------------- 
 166 // ---------------------------------------------------------------------------- 
 168 class WXDLLEXPORT wxTimerEvent 
: public wxEvent
 
 171     wxTimerEvent(int timerid 
= 0, int interval 
= 0) : wxEvent(timerid
) 
 173         m_eventType 
= wxEVT_TIMER
; 
 175         m_interval 
= interval
; 
 179     int GetInterval() const { return m_interval
; } 
 181     // implement the base class pure virtual 
 182     virtual wxEvent 
*Clone() const { return new wxTimerEvent(*this); } 
 187     DECLARE_DYNAMIC_CLASS_NO_ASSIGN(wxTimerEvent
) 
 190 typedef void (wxEvtHandler::*wxTimerEventFunction
)(wxTimerEvent
&); 
 192 #define wxTimerEventHandler(func) \ 
 193     (wxObjectEventFunction)(wxEventFunction)wxStaticCastEvent(wxTimerEventFunction, &func) 
 195 #define EVT_TIMER(timerid, func) \ 
 196     wx__DECLARE_EVT1(wxEVT_TIMER, timerid, wxTimerEventHandler(func)) 
 198 #endif // wxUSE_GUI && wxUSE_TIMER