Qt超時鎖屏的實現示例

概述

Qt實現超時鎖屏的功能(工控機觸摸屏),當手長時間不觸摸屏幕的時候,程序超時會顯示鎖屏窗口。

效果

主窗口超時顯示鎖屏窗口:

在這裡插入圖片描述

系統窗口超時顯示鎖屏窗口:

在這裡插入圖片描述

在這裡插入圖片描述

實現思路

  • 首先開啟一個線程用於QTimer定時器計時,最開始進入軟件開啟定時器計時,超時則顯示鎖屏窗口;而手觸摸屏幕會觸發鼠標點擊事件,則停止計時;而手離開屏幕會觸發鼠標釋放事件,則重新開始計時。
  • 因為是多窗口的應用軟件,所以需要監控全局鼠標事件,所以需要子類化QApplication類。

核心代碼

監控全局鼠標事件的類為GlobalApplication,其中也實現瞭開啟一個線程進行定時器計時,以及超時顯示鎖屏窗口的功能。

globalapplication.h 文件的內容如下:

class GlobalApplication : public QApplication
{
    Q_OBJECT

public:
     GlobalApplication(int&argc,char **argv);
     ~GlobalApplication();

     bool notify(QObject*, QEvent *);

private slots:
    void onTimeOut(); //超時鎖屏槽函數

private:
    myLockWindow *m_myLockWindow; //鎖屏窗口
    QObject *m_currWinObj; //鼠標事件發生時的當前所在窗口

    QTimer *m_pTimer; //定時器
    QThread *m_pThread; //定時器線程
};

註:Widget_Lock 為鎖屏窗口類,可以替換成你自己要顯示的窗口。

globalapplication.cpp 文件的內容如下:

#include "globalapplication.h"

GlobalApplication::GlobalApplication(int &argc,char **argv):
QApplication(argc,argv)
{

    m_currWinObj = new QObject(); //初始化鼠標事件發生時的當前所在窗口

    //初始化定時器線程和定時器
    m_pThread = new QThread(this);
    m_pTimer = new QTimer();
    m_pTimer->moveToThread(m_pThread);
    m_pTimer->setInterval(4000);
    connect(m_pThread, SIGNAL(started()), m_pTimer, SLOT(start()));
    connect(m_pTimer, SIGNAL(timeout()),this,SLOT(onTimeOut()));
    //開啟線程,調用定時器的start()
    m_pThread->start();

    m_myLockWindow = new myLockWindow(); //初始化鎖屏窗口
    m_myLockWindow->m_unlockFlag = true; //初始化解除鎖屏成功標志
}

GlobalApplication::~GlobalApplication()
{
    //徹底結束線程(單獨的一個quit()無法徹底結束進程)
    m_pThread->requestInterruption();
    m_pThread->quit();
    m_pThread->wait();
}

bool GlobalApplication::notify(QObject *obj, QEvent *e)
{
    //因為鼠標點擊或滑動到任何窗口部件都會進入該函數,所以根據objectName()過濾窗口部件
    if(obj->objectName().right(1) == "W") //cleanW mainW
    {
        //工控機是觸摸屏,觸摸屏幕和滑動屏幕都會點擊屏幕,所以這裡隻檢測鼠標點擊事件
        if(e->type() == QEvent::MouseButtonPress) //不區分左右鍵按下瞭
        {
            //qDebug() << "objName:" << obj->objectName();
            //qDebug()<<"press stop";
            m_pThread->quit(); //線程結束後,則在此線程的定時器會自動停止計時
        }
        else if(e->type() == QEvent::MouseButtonRelease)
        {
            //qDebug()<<"release start";
            m_pThread->start(); //線程開始,會發送started()信號,啟動定時器的start()槽函數
        }

        m_currWinObj = obj; //獲得鼠標事件發生時的當前所在窗口
    }

    return QApplication::notify(obj,e);
}

//超時鎖屏槽函數
void GlobalApplication::onTimeOut()
{
    //m_unlockFlag為false,表示鎖屏窗口未關閉,則即使再超時也不會再顯示鎖屏窗口
    if(m_myLockWindow->m_unlockFlag == true) //當密碼輸入正確後,關閉鎖屏窗口,則會將m_unlockFlag設置為true
    {
        qDebug()<<"鎖屏";
        //創建鎖屏窗口對象,並顯示該窗口
        m_myLockWindow = new myLockWindow();
        m_myLockWindow->show();
        qDebug()<<"創建鎖屏窗口對象,並顯示該窗口";

        //這行代碼要放在最後,因為在構建對象時,會自動設置m_unlockFlag,所以在構建後要復位m_unlockFlag
        m_myLockWindow->m_unlockFlag = false;
    }
    else
    {
        qDebug()<<"重復鎖屏";
    }
}

測試函數

int main(int argc, char *argv[])
{
    GlobalApplication a(argc, argv);

    QDesktopWidget *desktopWidget = QApplication::desktop();
    QRect screenRect = desktopWidget->screenGeometry();
    qDebug()<<screenRect.width();
    qDebug()<<screenRect.height();

    //獲取計算機名稱
    QString localHostName = QHostInfo::localHostName();
    qDebug() << "計算機名:" << localHostName;

    QPixmap pixmap(":/HeadImage.png"); // 裝載圖片
    QSplashScreen splash(pixmap); // 初始化圖片到QSplashScreen
    splash.show(); // 顯示圖片
    a.processEvents(); // 刷新事件循環

    Widget w;
    splash.finish(&w); // 完成後自動close

     w.show();

    return a.exec();
}

到此這篇關於Qt超時鎖屏的實現示例的文章就介紹到這瞭,更多相關Qt超時鎖屏內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: