Ⅰ linux怎麼用qt creator製作數字時鍾
//可以直接用QDateTime的格式化輸出就行了。不用區分linux或windows
QStringstrDateTime=QDateTime::currentDateTime().toString("yyyy年MM月dd日hh:mm:ss"敬信);
//然後找個label來顯示這個時間就行了
labelTime->setText(strDateTime);
//當然這個只能顯示一次,因此你需要一個定時器來刷新這個亮耐輪時間
QTimer*timer=畝唯newQTimer();
//設置定時器超時時間1s,這樣就可以看到動態的數字時鍾了
timer->start(1000);//單位是毫秒
//然後關聯信號槽
connect(timer,SIGNAL(timeout()),this,SLOT(sltTimeout()));
//sltTimeout就是你的槽函數,然後把上面獲取和顯示時間的代碼放進來就行了
Ⅱ Qt中定時器的兩種使用方法(QObject類與QTimer類)
Qt中定時器用於間隔一段時間執行一次操作,循環執慎汪行,直至定哪拍時器停止或被殺死。有兩種使用方法, QObject類 與 QTimer類 。個人比較習慣使用QTimer類,信號與槽方式比較簡潔靈活。
方法一:QObject中的定時器的使用,需要用到三個函數
1、int QObject::startTimer ( int interval ) ; //開啟定時器,執行周期為interval毫秒。
此函數開啟成功後,返回這個定時器的ID,並每隔interval毫秒時間進入一次timeEvent函數,直至定時器停止或被殺死。
2、void QObject::timeEvent ( QTimerEvent *event ) ; //需重寫timeEvent函數,相關操作在此函數中執行。
當定時器超時後會進入此函數,可以通過event->timerId()來確定當前執行的寬緩仔定時器是哪個。
3、void QObject::killTimer ( int id ); //殺死目的id號的定時器,停止循環。
示例:
方法二:使用QTimer類(信號與槽)
1、創建QTimer類對象,
QTimer *m_timer= new QTimer ( this ) ;
2、連接信號與槽,定時器超時後會發出 timeout () 信號,超時時執行槽函數 mySlot()
connect ( timer , SIGNAL ( timeout()) , this ,SLOT( mySlot()) );
3、開啟定時器,周期為msec毫秒
timer->start( msec );
Ⅲ qt 要開啟多個定時器
//背景時12個帕爾貼 不要12個溫度去曲線,每一個類鋒衡似下圖:
該類在線程啟動12定時器計時,銀輪做並停止,第13個定時器 定時讀取溫度
//頭文桐空件
class QThread;
class QTimer;
class ThreadTimer : public QObject
{
Q_OBJECT
public:
ThreadTimer();
~ThreadTimer();
public slots:
//index八連排索引, sec是秒 開啟定時器
void StartTimer(int index, int sec );
void StartGetTem( int timeout );
void StopGetTem( );
private:
void GetTem();
signals:
void TimeOut(int index);
private:
virtual void timerEvent(QTimerEvent event);
private:
QTimer * m_pTimer;
QThread m_pCurrThread;
int m_nTimer[MAX_REAGENT];
};
//源文件
ThreadTimer::ThreadTimer()
{
memset(m_nTimer,0,sizeof(m_nTimer));
m_pCurrThread = new QThread;
m_pTimer = new QTimer(this);
connect(m_pTimer, &QTimer::timeout, this, &ThreadTimer::GetTem);
this->moveToThread(m_pCurrThread);
m_pCurrThread->start();
}
ThreadTimer::~ThreadTimer()
{
if( nullptr != m_pCurrThread)
{
m_pCurrThread->quit();
m_pCurrThread->wait();
m_pCurrThread->deleteLater();
}
}
void ThreadTimer::StartTimer(int index, int timeout )
{
m_nTimer[index] = startTimer( timeout* 1000);
}
void ThreadTimer::StartGetTem( int timeout )
{
m_pTimer->start( timeout*1000 );
}
void ThreadTimer::StopGetTem( )
{
m_pTimer->stop();
}
//計時任務
void ThreadTimer::timerEvent(QTimerEvent *event)
{
int timerID = event->timerId();
for( int i=0;i< MAX_REAGENT;i++)
{
if( timerID == m_nTimer[i])
{
m_nTimer[i] = -1;
emit TimeOut(i);
break;
}
}
qDebug()<<"ThreadTimer::timerEvent "<<QThread::currentThreadId()<<"
";
killTimer( timerID );
}
//獲取溫度
void ThreadTimer::GetTem()
{
}
Ⅳ qt中定時器啟動後是在不斷的循環定時嗎 比如定義一個1s定時器 1s後它又重新開始定時嗎
不巧差一定.
QTimer 是橘扒可以選是圓寬昌否重新開始計時的.
void setSingleShot(bool singleShot). 這個函數可以用來控制.
Ⅳ qt定時器限制定時次數
使用QTimer::setInterval()和QTimer::start()函數可以實現定時器的限制定時次數,具體步驟如下:
1. 定義一個計數器,用於記錄定時器的執行次數;消彎
2. 創建QTimer對象,並設置定時器的時間間隔沖團;
3. 將計數器與QTimer對象連接,在定時器超時時,計數器加1;
4. 在定時器超時時,判斷計數器是否達到限定次數,如果達到,則停止定拿判悶時器,否則繼續執行定時器;
5. 最後調用QTimer::start()函數,開始定時器的計時。
Ⅵ Linux 下 Qt關於微秒級別的定時器
select可以達到微妙級別,態如你網路下select timer,下面是win下面使用洞念select的例子
#include<iostream>
#include <iomanip>
#include <windows.h>
#include <winsock.h>
#pragma comment(lib, "ws2_32.lib")
using namespace std;
int main()
{
DWORD dwVersion = 0; WSADATA wsaData; DWORD dwErr = 0;
dwErr = WSAStartup(MAKEWORD(0x2, 0x2), &wsaData);
if (0 != dwErr)
{printf("winsock init error!\n");return -1;}
SOCKET s = socket(AF_INET, SOCK_STREAM, 0);
if (INVALID_SOCKET == s)
{
printf("create a socket error!\n");
WSACleanup();
return -1;
}
// 設置為納閉困非阻塞
int nRet = 0;
u_long lRet = 1;
nRet = ioctlsocket(s, FIONBIO, &lRet);
if (SOCKET_ERROR == nRet)
{
printf("set socket error!\n");
closesocket(s);
WSACleanup();
return -1;
}
int time=0;
while( 1 ){
fd_set rfds ;
struct timeval tval;
FD_ZERO( &rfds ) ;
FD_SET(1,&rfds);
tval.tv_sec = 1 ; /*秒*/
tval.tv_usec =0 ; /*微秒, 1秒=10的3次方毫秒=10的6次方微妙*/
int ret =select( 1, &rfds, NULL, NULL, &tval );
if(ret==0 ){
cout<<setfill('0')<<setw(3)<<++time<<" s"<<endl;
}
else
{cout<<WSAGetLastError()<<endl;
break;
}
}
WSACleanup();
return 0;
}
Ⅶ Qt中定時器問題
不要在事件中創建定時器。在窗體類中定義定時器,在事件冊謹中激慶孫活定時器就可以了。
使用州差基方法,網上有很多例子,可以看:
http://blog.tianya.cn/blogger/post_show.asp?BlogID=2727722&PostID=23172320
Ⅷ qt 的qtime定時器怎麼選
可以用系統的timeEvent(QTimeEvent *e);
還可以用QTimer。
//方法一QTimer
QTimer*timer=newQTimer(this);
timer->乎桐start(1000);
connect(timer,SIGNAL(timeout()),this,SLOT(sltTimeout());
//方法二timeEvent
intm_nTimerId=startTimer(1000);
void磨備MainWidget::timerEvent(QTimerEvent*event)
{
if(event->timerId()==m_nTimerId){
dosomething();
瞎頃毀....
}
}
Ⅸ qt定時器函數執行時間長
如果Qt中的定時器函數執行時間太長,可能會導致界面卡頓或響應不及時。這可能是因為定時器回調函數中執行了耗時操作或者因為定時器的間隔設置過短,導致頻繁調用定時器回調函數。為了解決這個問題,可以採取以下措施:
1. 將耗時操作遷移到後台線程中執行,避免阻塞主線程。
2. 調整定時器間隔,避免頻繁調用定時器回調函數。如果定時器回調函數確實需要頻繁執行,可以考慮適當提高定時器回調函數的優先順序。
3. 對定時器回調函數進行優化,在保證功能正確的前提下,盡可能減少執行時間。
4. 對界面進行分析,找出可能導致卡頓的原因,進行優化。
綜上所述,避免定時器螞虛老回調函數執行時間過長是提高Qt應用程序運行效譽汪率、提升悶升用戶體驗的重要措施之一。