There are two ways to use timers in Qt, one is to use the Qobiect class, and one is to use the Qtimer class. The accuracy of the timer depends on the operating system and hardware, and most platforms support 20ms accuracy
Timers for the 1.QObject class
Qobject is the base class for all Qt objects, and it provides a basic timer. by Qobject::starttimer (), a one-millisecond interval can be used as a parameter to start the timer, which returns the identifier of a unique integer timer. This timer starts at each interval "trigger" until the end of the Qobject::killtimer () is explicitly invoked using the identifier of the timer.
When the timer is triggered, the application sends a qtimerevent. In the event loop, the processor handles timer events in the order of the event queues. When the processor is busy with other event processing, the timer cannot be processed immediately.
The Qobject class also provides time-definite functionality. Timer-related member functions are: Starttimer (), Timeevent (), KillTimer (). The Starttimer () and TimerEvent () prototypes in the Qobject base class are described below:
int qobject::starttimer (int interval);
Starts a timer and returns the timer ID, and returns 0 if a timer cannot be started. Once the timer starts, a timeout event is triggered every interval millisecond interval until KillTimer () is called to remove the timer. If interval is 0, there is no window System event handling for each time the timer event occurs.
virtual void qobject::timerevent (Qtimerevent *event);
The virtual function timerevent () is overloaded to implement the user's Timeout event handler function. If more than one timer is running, Qtimerevent::timerid () is used to find the specified timer and operate on it.
When the timer event occurs, the virtual function timerevent () is called along with the Qtimerevent event parameter class, which overloads the function to obtain the timer event.
The usage of the timer is as follows:
Header file
Class Qnewobject:public Qobject
{
Q_object
Public
Qnewobject (qobject * parent = 0);
Virtual ~qnewobject ();
Protected
void TimerEvent (Qtimerevent *event);
int M_ntimerid;
};
source file
Qnewobject::qnewobject (Qobject * parent)
: Qnewobject (parent)
{
M_ntimerid = Starttimer (1000);
}
Qnewobject::~qnewobject ()
{
if (M_ntimerid! = 0)
KillTimer (M_ntimerid);
}
void Qnewobject::timerevent (Qtimerevent *event)
{
Qdebug ("Timer event, id%d", Event->timerid ());
}
2. Timer class Qtimer
The Timer class Qtimer provides a timer that emits a signal when the timer is triggered, and he provides a timeout event that is triggered only once, usually using the following method:
Creating timers
Qtimer *testtimer = new Qtimer (this);
Connect the timer timeout signal to the slot (function function).
Connect (Testtimer, SIGNAL (timeout ()), this, SLOT (TestFunction ()));
Start running the timer at a timed interval of 1000ms
Testtimer->start (1000);
...
Stop running the timer
if (Testtimer->isactive ())
Testtimer->stop ();
Qtimer also provides a simple function singleshot () with only one timer. A timer triggers the processing function animatetimeout () after 100ms and fires only once. The code is as follows:
Qtimer::singleshot (+, this, SLOT (Animatetimeout ()));
The Qtimer class provides a timer signal and a single trigger timer.
It uses timer events internally to provide a more general-purpose timer. Qtimer is easy to use: Create a Qtimer, use Start () to start and connect its timeout () to the appropriate slot. When this time passes, it will emit a timeout () signal.
Note that when the parent object of Qtimer is destroyed, it is also automatically destroyed.
Instance:
Qtimer *timer = new Qtimer (myObject); Connect (timer, SIGNAL (), MyObject, SLOT (Timerdone ())); Timer->start (+, TRUE); 2-second single-Trigger timer
You can also use the static Singleshot () function to create a single trigger timer.
As a special case, once all the events in the Window System event queue have been processed, a qtimer of 0 will be up to the time.
This can also be used when providing a quick user interface to do more heavy work.
Qtimer *t = new Qtimer (myObject); Connect (t, SIGNAL (), SLOT (Processonething ())); T->start (0, FALSE);
Myobject->processonething () will be repeated and should be returned very quickly (usually after processing a data item) so that QT can send the event to the widget and stop the timer once it finishes the job. This is a typical way of doing a lot of work in a graphical user interface application, and now multithreading can be used on more and more platforms, and we want the invalid events to eventually be replaced by threads.
Note that the accuracy of the qtimer depends on the operating system and hardware underneath. Most platforms support 20 milliseconds of accuracy, and some platforms can provide higher. If QT does not transmit the required number of timer triggers, it will silently discard some.
Another way to use Qtimer is to call Qobject::starttimer () for your object and re-implement the Qobject::timerevent () event handler in your class (which must inherit qobject, of course). The disadvantage is that timerevent () does not support advanced levels such as single-trigger timers or signals.
Some operating systems limit the number of timers that may be used, and QT will try to work within the limits.
Http://blog.chinaunix.net/uid-22159621-id-3049267.html
Use timers in QT (can be performed using qobject::timerevent timing, qtimer::singleshot can only be triggered once)