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的格式转化
connect to和connect with的区别
QTime
fromString(const QString & string, Qt::DateFormat format = Qt::TextDate)
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小时内删除。