2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: timer.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxTimer
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxTimer
|
|
|
|
@wxheader{timer.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
The wxTimer class allows you to execute code at specified intervals. Its
|
|
|
|
precision is platform-dependent, but in general will not be better than 1ms nor
|
|
|
|
worse than 1s.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
There are three different ways to use this class:
|
2008-03-08 14:43:31 +00:00
|
|
|
|
|
|
|
You may derive a new class from wxTimer and override the
|
2008-03-08 13:52:38 +00:00
|
|
|
wxTimer::Notify member to perform the required action.
|
2008-03-08 14:43:31 +00:00
|
|
|
Or you may redirect the notifications to any
|
2008-03-08 13:52:38 +00:00
|
|
|
wxEvtHandler derived object by using the non-default
|
2008-03-08 14:43:31 +00:00
|
|
|
constructor or wxTimer::SetOwner. Then use the @c EVT_TIMER
|
|
|
|
macro to connect it to the event handler which will receive
|
2008-03-08 13:52:38 +00:00
|
|
|
wxTimerEvent notifications.
|
2008-03-08 14:43:31 +00:00
|
|
|
Or you may use a derived class and the @c EVT_TIMER
|
2008-03-08 13:52:38 +00:00
|
|
|
macro to connect it to an event handler defined in the derived class.
|
|
|
|
If the default constructor is used, the timer object will be its
|
|
|
|
own owner object, since it is derived from wxEvtHandler.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
|
|
|
In any case, you must start the timer with wxTimer::Start
|
2008-03-08 13:52:38 +00:00
|
|
|
after constructing it before it actually starts sending notifications. It can
|
|
|
|
be stopped later with wxTimer::Stop.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-01 13:59:28 +00:00
|
|
|
@note A timer can only be used from the main thread.
|
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 wxStopWatch
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxTimer : public wxEvtHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
2008-03-08 14:43:31 +00:00
|
|
|
Creates a timer and associates it with @e owner. Please see
|
2008-03-08 13:52:38 +00:00
|
|
|
SetOwner() for the description of parameters.
|
|
|
|
*/
|
|
|
|
wxTimer();
|
2008-03-09 12:33:59 +00:00
|
|
|
wxTimer(wxEvtHandler* owner, int id = -1);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor. Stops the timer if it is running.
|
|
|
|
*/
|
|
|
|
~wxTimer();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the ID of the events generated by this timer.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
int GetId() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the current interval for the timer (in milliseconds).
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
int GetInterval() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the current @e owner of the timer.
|
2008-03-08 14:43:31 +00:00
|
|
|
If non-@NULL this is the event handler which will receive the
|
2008-03-08 13:52:38 +00:00
|
|
|
@ref overview_wxtimerevent "timer events" when the timer is running.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxEvtHandler GetOwner() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the timer is one shot, i.e. if it will stop after firing the
|
|
|
|
first notification automatically.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsOneShot() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the timer is running, @false if it is stopped.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsRunning() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
This member should be overridden by the user if the default constructor was
|
|
|
|
used and SetOwner() wasn't called.
|
|
|
|
Perform whatever action which is to be taken periodically here.
|
|
|
|
*/
|
|
|
|
void Notify();
|
|
|
|
|
|
|
|
/**
|
2008-03-09 12:33:59 +00:00
|
|
|
Associates the timer with the given @a owner object. When the timer is
|
2008-03-08 13:52:38 +00:00
|
|
|
running, the owner will receive @ref overview_wxtimerevent "timer events" with
|
2008-03-09 12:33:59 +00:00
|
|
|
id equal to @a id specified here.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void SetOwner(wxEvtHandler* owner, int id = -1);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-09 12:33:59 +00:00
|
|
|
(Re)starts the timer. If @a milliseconds parameter is -1 (value by default),
|
2008-03-08 13:52:38 +00:00
|
|
|
the previous value is used. Returns @false if the timer could not be started,
|
|
|
|
@true otherwise (in MS Windows timers are a limited resource).
|
2008-03-09 12:33:59 +00:00
|
|
|
If @a oneShot is @false (the default), the Notify()
|
2008-03-08 13:52:38 +00:00
|
|
|
function will be called repeatedly until the timer is stopped. If @true,
|
|
|
|
it will be called only once and the timer will stop automatically. To make your
|
|
|
|
code more readable you may also use the following symbolic constants:
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxTIMER_CONTINUOUS
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Start a normal, continuously running, timer
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxTIMER_ONE_SHOT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Start a one shot timer
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
If the timer was already running, it will be stopped by this method before
|
|
|
|
restarting it.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool Start(int milliseconds = -1, bool oneShot = false);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Stops the timer.
|
|
|
|
*/
|
|
|
|
void Stop();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxTimerEvent
|
|
|
|
@wxheader{timer.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxTimerEvent object is passed to the event handler of timer events.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
For example:
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@code
|
|
|
|
class MyFrame : public wxFrame
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
...
|
|
|
|
void OnTimer(wxTimerEvent& event);
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
private:
|
|
|
|
wxTimer m_timer;
|
|
|
|
};
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|
|
|
EVT_TIMER(TIMER_ID, MyFrame::OnTimer)
|
|
|
|
END_EVENT_TABLE()
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
MyFrame::MyFrame()
|
|
|
|
: m_timer(this, TIMER_ID)
|
|
|
|
{
|
|
|
|
m_timer.Start(1000); // 1 second interval
|
|
|
|
}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
void MyFrame::OnTimer(wxTimerEvent& event)
|
|
|
|
{
|
|
|
|
// do whatever you want to do every second here
|
|
|
|
}
|
|
|
|
@endcode
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxbase}
|
|
|
|
@category{events}
|
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
|
|
|
*/
|
|
|
|
class wxTimerEvent : public wxEvent
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Returns the interval of the timer which generated this event.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
int GetInterval() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the timer object which generated this event.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxTimer GetTimer() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|