Qt之QTimer和QTime
QTimer Class
QTimer是一个计时器类
它的使用分三步,创建对象,连接signal和slot函数,start()
1.QTimer *timer = new QTimer(this);
2.connect(timer, SIGNAL(timeout()), this, SLOT(update()));
3.timer->start(1000);
其中,SIGNAL(timeout())表示:每当计时结束,计时器归零并重新计时,并发送一个信号激活slot函数。
而 timer->start(1000);当中的1000,就是1000毫秒的意思,表示每次timeout的时间间隔是1000ms
如果我们想让这个计时器只计时一次,那么必须使用void setSingleShot(bool singleShot)函数。
1.QTimer *timer = new QTimer(this);
2.connect(timer, SIGNAL(timeout()), this, SLOT(update()));
3.timer->setsetSingleShot(true)
4.timer->start(60000);
这样计时器只会倒计时1分钟,然后结束。
当然我们还可以改变计时周期
void setInterval(int msec)
QTime Class
QTime 提供时间函数给用户使用,它和QTimer的区别就和手表与秒表的区别一样。
QTime主要用于对时间的操作,他提供了大量的函数便于用户对时间进行转换和计算。
类型 | 名称 | 说明 |
QTime() | 构造一个时间为0的对象 | |
QTime(int h, int m, int s = 0, int ms = 0) | 构造一个具有初始时间的对象 | |
QTime | addMSecs(int ms) const | 在当前时间基础上增加ms毫秒,ms可为负 |
QTime | addSecs(int s) const | 在当前时间基础上增加s秒,s可为负 |
int | hour() const | 返回小时数 |
int | minute() const | 返回分钟数 |
int | second() const | 返回秒 |
int | msec() const | 返回毫秒 |
bool | isValid() const | 判断当前对象的时间是否有效,毕竟1天不可能有25小时,也不会存在1分61秒 |
bool | isValid(int h, int m, int s, int ms = 0) | 判断输入的时间是否有效 |
int | msecsTo(const QTime & t) const | 计算距离时间t的毫秒数,如果t早于当前时间,则为负 |
int | secsTo(const QTime & t) const | 计算距离时间t的秒数 |
bool | setHMS(int h, int m, int s, int ms = 0) | 设置标准HMS时间,如果不符合标准,返回false |
下面是最重要的几个 | ||
void | start() | 将当前系统时间记录为当前时间 |
int | restart() | 将当前系统时间记录为当前时间,并返回距离上次呼叫start()或者restart()函数间隔的毫秒数 |
int | elapsed() const | 计算与最近一次呼叫start()或者restart()函数间隔的毫秒数,相当于计时器 |
QString | toString(const QString & format) const | 将时间转化为特定的字符串格式 |
QString | toString(Qt::DateFormat format = Qt::TextDate) const | 按照Qt::DateFormat的格式转化 |
QTime | fromString(const QString & string, Qt::DateFormat format = Qt::TextDate) | connect to和connect with的区别从Qt::DateFormat转化为QTime对象 |
QTime | fromString(const QString & string, const QString & format) | 从特定的字符串格式转化为QTime对象 |
QTime | currentTime() | 得到当前的系统时间 |
此外,const QString & format需要特别说明,表格如下:
Expression | Output |
h | the hour without a leading zero (0 to 23 or 1 to 12 if AM/PM display) |
hh | the hour with a leading zero (00 to 23 or 01 to 12 if AM/PM display) |
H | the hour without a leading zero (0 to 23, even with AM/PM display) |
HH | the hour with a leading zero (00 to 23, even with AM/PM display) |
m | the minute without a leading zero (0 to 59) |
mm | the minute with a leading zero (00 to 59) |
s | the second without a leading zero (0 to 59) |
ss | the second with a leading zero (00 to 59) |
z | the milliseconds without leading zeroes (0 to 999) |
zzz | the milliseconds with leading zeroes (000 to 999) |
AP | interpret as an AM/PM time. AP must be either “AM” or “PM”. |
ap | Interpret as an AM/PM time. ap must be either “am” or “pm”. |
t | the timezone (for example “CEST”) |
例子:
Format | Result |
hh: | 14:13:09.042 |
h:m:s ap | 2:13:9 pm |
H:m:s a | 14:13:9 pm |
而Qt::DateFormat又分为很多种,比如Qt::TextDate、Qt::ISODate等
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论