用Qt自制一个小闹钟

小闹钟 

功能

当按下启动按钮时,停止按钮可用,启动按钮不可用,闹钟无法设置,无法输入自定义内容

当按下停止按钮时,暂停播报,启动按钮可用,闹钟可以设置,可以输入自定义内容

.pro文件

QT       += core gui texttospeech
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

CONFIG += c++11

# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS

# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

SOURCES += \
    main.cpp \
    widget.cpp

HEADERS += \
    widget.h

FORMS += \
    widget.ui

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

RESOURCES += \
    Icon.qrc

widget.h文件

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QTimer>      //定时器类
#include <QTime>       //时间类
#include <QTimerEvent>   //定时器事件类的头文件
#include <QDateTime>     //日期时间类
#include <QDateTimeEdit>
#include <QDebug>
#include <QTextToSpeech>    //朗读
#include <QTextEdit>
#include <QMetaObject>
QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();
    //重写定时器事件处理函数
    void timerEvent(QTimerEvent *event)override;



signals:
    void my_signal();
private slots:
    void on_pushButton_clicked();

    void on_pushButton_2_clicked();


private:
    Ui::Widget *ui;
    //定义一个定时器的id
    int timer_id;        //基于事件处理函数的定时器
    int timer_id1;
    QTextToSpeech *speech;
    int i = 0;
    int flag = 0;
    QString text;
    QDateTime sys_dt;


};
#endif // WIDGET_H

main.cpp文件

#include "widget.h"

#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();
    return a.exec();
}

widget.cpp文件

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    this->setWindowTitle("小闹钟");
    timer_id = this->startTimer(5);
    ui->pushButton_2->setEnabled(false);
    ui->textEdit->setPlaceholderText("请输入闹钟响时播报的内容");
    this->setWindowIcon(QIcon(":/new/prefix1/666.png"));

}

Widget::~Widget()
{
    delete ui;
}

void Widget::timerEvent(QTimerEvent *event)
{
    if(event->timerId()) //== timer_id)  //用来判断不同的定时器的id
    {
        //获取当前系统的日期时间
        sys_dt = QDateTime::currentDateTime();
        //展示时间到ui界面的lable2中
        ui->label->setText(sys_dt.toString("yyyy-MM-dd hh:mm:ss"));
        //居中显示               标签文本对齐方式
        ui->label->setAlignment(Qt::AlignCenter);

        ui->label->setFont(QFont("微软雅黑",20));

        QString timeText = sys_dt.toString("yyyy-MM-dd hh:mm:ss");
        QString timeText1 = ui->dateTimeEdit->text();
        if(flag == 1)
        {

            if(timeText1 == timeText)
            {
                speech->say(text); // 朗读文本

            }
        }
    }
}
void Widget::on_pushButton_clicked()
{
    flag = 1;
    speech = new QTextToSpeech;
    text = ui->textEdit->toPlainText();
    ui->pushButton_2->setEnabled(true);
    ui->pushButton->setEnabled(false);
    ui->textEdit->setEnabled(false);
    ui->dateTimeEdit->setEnabled(false);
}

void Widget::on_pushButton_2_clicked()
{
    flag = 0;
    ui->pushButton->setEnabled(true);
    ui->pushButton_2->setEnabled(false);
    ui->textEdit->setEnabled(true);
    ui->dateTimeEdit->setEnabled(true);
    speech->stop();
}

widget.ui文件

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ck钉钉钉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值