目录
  • 一、项目介绍
  • 二、项目基本配置
  • 三、UI界面设计
  • 四、主程序实现
    • 4.1 添加新文件
    • 4.2 digiclock.h头文件
    • 4.3 digiclock.cpp源文件
    • 4.4 main.cpp源文件
  • 五、效果演示

    一、项目介绍

    利用Qt实现显示与桌面上并可以随意拖拽至桌面任意位置的电子时钟案例。

    Qt实现电子时钟的示例代码

    二、项目基本配置

    新建一个Qt案例,项目名称为“Clock”,基类选择“QDialog”,取消创建UI界面复选框的选中状态。

    Qt实现电子时钟的示例代码

    三、UI界面设计

    无UI界面

    四、主程序实现

    4.1 添加新文件

    添加新文件:

    Qt实现电子时钟的示例代码

    选择“C++ Class”选项,单击“Choose”按钮,选择“Base class”文本框中输入基类名“QLCDNumber”(手动添加),在“Class name”文本框中输入类的名称“DigiClock”:

    Qt实现电子时钟的示例代码

    4.2 digiclock.h头文件

    代码如下:

    #ifndef DIGICLOCK_H
    #define DIGICLOCK_H
    
    #include <QLCDNumber>
    
    class DigiClock : public QLCDNumber
    {
        Q_OBJECT
    public:
        DigiClock(QWidget *parent=0);
        void mousePressEvent(QMouseEvent *);
        void mouseMoveEvent(QMouseEvent *);
    
    public slots:
        void showTime();    //显示当前时间
    
    private:
        QPoint dragPosition;  //保存鼠标点相对电子时钟窗体左上角的偏移量
        bool showColon;       //用于显示时间时是否显示:
    };
    
    #endif // DIGICLOCK_H
    

    4.3 digiclock.cpp源文件

    首先,DigiClock类继承自QLCDNumber类:

    DigiClock::DigiClock(QWidget *parent):QLCDNumber(parent)
    {
    //设置时钟背景
    QPalette p=palette();//定义调色板对象
    p.setColor(QPalette::Window,Qt::blue);//设置背景颜色为蓝色
    setPalette(p);//启用调色板对象
    setWindowFlags(Qt::FramelessWindowHint);//生成无边界窗口
    setWindowOpacity(0.5);//设置窗体透明度为0.5
    QTimer *timer=new QTimer(this);//新建定时器对象
    connect(timer,SIGNAL(timeout()),this,SLOT(showTime()));//连接定时器地timeout()信号与显示时间的槽信号showTime()
    timer->start(1000);//启动定时器(每隔1000ms启动一次)
    showTime();//初始时间显示
    resize(150,60);//设置电子时钟显示的尺寸
    showColon=true;//初始化
    
    }
    

    然后定义槽函数showTime(),完成电子钟的显示时间功能:

    //槽函数showTime()
    void DigiClock::showTime()
    {
        QTime time=QTime::currentTime();    //获取当前系统时间
        QString text=time.toString("hh:mm");//获取的当前时间转换为字符串类型
        if(showColon)                        //控制:闪烁
        {
            text[2]=':';
            showColon=false;
        }
        else
        {
            text[2]=' ';
            showColon=true;
        }
        display(text);    //显示转换好的字符串时间
    }
    

    接着,定义鼠标按下事件响应函数:

    //鼠标按下事件响应函数
    void DigiClock::mousePressEvent(QMouseEvent *event)
    {
        if(event->button()==Qt::LeftButton) //判断按下键是否为鼠标左键
        {
            //dragPosition=event->globalPos()-frameGeometry().topLeft();
            dragPosition=event->pos();//两种方法
            //event->accept();//接收事件
        }
        if(event->button()==Qt::RightButton)    //若按下键为鼠标右键
        {
            close();//退出
        }
    }
    

    定义鼠标移动事件响应函数,实现拖拽功能:

    //鼠标移动响应函数
    void DigiClock::mouseMoveEvent(QMouseEvent *event)
    {
        if(event->buttons()&Qt::LeftButton)
        {
            move(event->globalPos()-dragPosition);
            //event->accept();//接收事件
        }
    }
    

    4.4 main.cpp源文件

    代码如下:

    #include "dialog.h"
    #include <QApplication>
    #include"digiclock.h"
    int main(int argc, char *argv[])
    {
        QApplication a(argc, argv);
    
        DigiClock clock;
        clock.show();
    //    Dialog w;
    //    w.show();
        return a.exec();
    }
    

    五、效果演示

    Qt实现电子时钟的示例代码

    声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。