在我的一个项目中,我正在使用QTimer,我想知道是否有可能获得QTimer的剩余时间,以便让用户知道“下次超时的时间:10秒”或类似的东西。 .. 那可能吗?如果不是这样,有没有关于如何实现这一点的好主意?
也许我要写自己的计时器......
答案 0 :(得分:6)
这是你在找什么? QTimer :: elapsed()使用计算机时钟,因此根据您的平台,精度会有所不同。
class MyTimer : QTimer
{
MyTimer(QObject* parent) : QTimer(parent)
{
connect(this, timeout(), this, resettime());
}
int start()
{
m_time.start();
return QTimer::start();
}
int start(int msec)
{
m_time.start();
return QTimer::start(msec)l
}
int timeLeft()
{
return interval()-m_time.elapsed()
}
private slots:
void resettime()
{
m_time.restart();
}
private:
QTime m_time;
}
答案 1 :(得分:3)
感谢您的建议,但我找到了另一种解决方案。我写了自己的类my_timer,它只是在内部辅助计时器上,每秒都超时。在我的主窗口中,我将此超时与一个函数连接,并更新用户的显示。
my_timer.cpp:
#include "my_timer.hpp"
my_timer::my_timer( QWidget *parent ) : QTimer( parent )
{
notifier = new QTimer;
}
my_timer::~my_timer()
{
//...
}
QTimer* my_timer::get_notifier()
{
return notifier;
}
void my_timer::start( int msec )
{
QTimer::start( msec );
notifier->start( 1000 );
}
void my_timer::stop()
{
QTimer::stop();
notifier->stop();
}
在我的main_window.cpp中:
void main_window::setup_connects()
{
// ...
connect( m_timer->get_notifier(), SIGNAL(timeout()), this, SLOT(on_update_label()) );
// ...
}
void main_window::on_update_label()
{
if( m_timer->isActive() )
{
if( remaining_secs > 1 )
{
remaining_secs--;
}
else
{
remaining_secs = spin_box->value();
}
update_label();
}
}
void main_window::update_label()
{
m_time_string = QString( "Remaining time until next execution: %1" ).arg( remaining_secs );
m_time_label->setText( m_time_string );
}
答案 2 :(得分:2)
查看QObject的timerEvent
事件。我认为你可以用这个达到你想要的目标。
答案 3 :(得分:1)
为了完整起见:
#ifndef _ELAPSED_TIMER_H_
#define _ELAPSED_TIMER_H_
#include <QTimer>
#include <QTime>
/*
* convenience class, which can return the proportion of the time left. usefull for interpolation
* tasks
**/
class ElapsedTimer : public QTimer
{
Q_OBJECT
public:
ElapsedTimer(QObject* parent) : QTimer(parent)
{
connect(this, SIGNAL(timeout()), this, SLOT(resettime()));
}
void start()
{
m_time.start();
QTimer::start();
}
void start(int msec)
{
m_time.start();
QTimer::start(msec);
}
double proportionLeft()
{
return (interval()-m_time.elapsed())/interval();
}
int timeLeft()
{
return interval()-m_time.elapsed();
}
private slots:
void resettime()
{
m_time.restart();
}
private:
QTime m_time;
};
#endif/*_ELAPSED_TIMER_H_*/