我是靠谱客的博主 认真路灯,最近开发中收集的这篇文章主要介绍QT基础之QPalette实例电子时钟,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

文章目录

      • 代码链接
      • 简介
      • 代码展示

更多参见
QT基础与实例应用目录

代码链接

GitHub链接 :ClockExample

简介

借助QLCDNumber实现电子时钟,可以随意拖拽到桌面任意位置,鼠标右键进行关闭,用于实践QPalette类、QTimer的使用以及mousePressEvent`mouseMoveEventmouseDoubleClickEvent`事件处理函数的使用。可在此基础上扩展其他应用,参看Qt帮助手册。

请添加图片描述

注意:

1、mouseMoveEventmousePressEvent 在 区分左右键的方法

2、QLCDNumber 设置Flat才能改变前景色(数字颜色)。

3、QPoint dragOffsetPoint 的使用 // 保存拖拽鼠标点 相对时钟窗体左上角位置 的偏移值

请添加图片描述

代码展示

头文件

class DigiClock : public QLCDNumber
{
    Q_OBJECT

public:
    DigiClock(QWidget *parent = nullptr);
    ~DigiClock();
    void mousePressEvent(QMouseEvent *event); // 鼠标按下事件响应函数
    void mouseMoveEvent(QMouseEvent *event); // 鼠标移动事件响应函数
    void mouseDoubleClickEvent(QMouseEvent *event); // 鼠标双击事件响应函数
public slots:
    void showTime();
private:
    int colorIndex; // 颜色序号
    QList<Qt::GlobalColor> colorList; // 颜色列表
    bool showColonFlag; // 是否显示 :, 模拟闪烁
    QPoint dragOffsetPoint; // 保存拖拽鼠标点 相对时钟窗体左上角位置 的偏移值

};

Cpp文件

DigiClock::DigiClock(QWidget *parent)
    : QLCDNumber(parent)
{
    colorIndex = 0;
    colorList = {Qt::darkRed,Qt::darkGreen,Qt::darkBlue,
                 Qt:: darkCyan,Qt::darkMagenta,Qt::darkYellow,Qt::darkGray};
    //设值参数
    this->setWindowFlags(Qt::FramelessWindowHint); // 设置窗体标识,无边框无标题栏
    this->setDecMode(); // 十进制
    this->setDigitCount(19); //显示个数
    this->setWindowOpacity(0.5); // 设置透明度  0 全透明 1 全不透明
    this->setSegmentStyle(QLCDNumber::Flat); // flat 才能改变 前景色
    this->resize(600,100); // 重设大小

    QPalette p = this->palette();
    p.setColor(QPalette::Window,Qt::lightGray); // 背景色
    p.setColor(QPalette::WindowText,colorList.at(colorIndex)); // 前景色 字体颜色
    this->setPalette(p);

    QTimer *timer = new QTimer(this); //定时器用于 每秒刷新显示
    connect(timer,SIGNAL(timeout()),this,SLOT(showTime()));
    timer->start(1000);
    this->showTime(); // 初始时间显示
    showColonFlag = true;
}

DigiClock::~DigiClock()
{
}

void DigiClock::mousePressEvent(QMouseEvent *event)
{
    if(event->button() == Qt::LeftButton){ // 注意 mouseMoveEvent 的区别
        dragOffsetPoint = event->globalPos() - this->frameGeometry().topLeft();
        event->accept();
    }
    if(event->button() == Qt::RightButton){
        close(); // 关闭
    }
}

void DigiClock::mouseMoveEvent(QMouseEvent *event)
{
    // 注意这里和 mousePressEvent 的区别,在mouseMoveEvent中 event->button() 始终为 NoButton
    if(event->buttons() & Qt::LeftButton){
        move(event->globalPos() - dragOffsetPoint);
        event->accept();
    }
}

void DigiClock::mouseDoubleClickEvent(QMouseEvent *event)
{
    if(event->button() == Qt::LeftButton){
        colorIndex++;
        if(colorIndex >= colorList.size()){
            colorIndex = 0;
        }
        QPalette p = this->palette();
        p.setColor(QPalette::WindowText,colorList.at(colorIndex)); // 前景色 字体颜色
        this->setPalette(p);
        event->accept();
    }
}

void DigiClock::showTime()
{
    QDateTime dateTime = QDateTime::currentDateTime();
    QString text = dateTime.toString("yyyy-MM-dd hh:mm:ss"); // 19个数
    if(showColonFlag){
        showColonFlag = false;
        text[16] = ':';
    } else {
        showColonFlag = true;
        text[16] = ' ';
    }
    this->display(text); // 显示
}

在此基础上可以扩展更多应用。

希望我的文章对于大家有帮助,由于个人能力的局限性,文中可能存在一些问题,欢迎指正、补充!

最后

以上就是认真路灯为你收集整理的QT基础之QPalette实例电子时钟的全部内容,希望文章能够帮你解决QT基础之QPalette实例电子时钟所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部