2023.05.03 QT 制作小闹钟

按下开启后,不可编辑,闹钟启动

按下关闭,可以编辑闹铃播报内容以及时间 ,  停止语音播报;

代码部分:

.pro

QT       += core gui texttospeech

.h

 #ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QTimer>           //定时器类
#include <QTime>            //时间类
#include <QString>
#include <QDateTime>        //日期时间类
#include <QTextToSpeech>    // 语音播报

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

private slots:
    void on_timeout_solt();

    void on_pushButton_clicked();

    void on_pushButton_2_clicked();

private:
    Ui::Widget *ui;
    //使用定时器类,定义一个定时器指针
    QTimer *timer;

    //定义语音播报
    QTextToSpeech *speech;
};
#endif // WIDGET_H

.cpp

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

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //给定时器指针实例化空间
    timer = new QTimer(this);
    connect(timer,&QTimer::timeout,this,&Widget::on_timeout_solt);
    //设置播报
    speech = new QTextToSpeech(this);
    //启动定时器后每隔一秒自动发射timeout信号
    timer->start();
}

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

//处理timeout信号对应的槽函数
void Widget::on_timeout_solt()
{
    //获取时间
    QTime t = QTime::currentTime();
    //设置格式
    QString t1 = t.toString("hh:mm:ss");
    //将时间展示到label上
    ui->label->setText(t1);
    //如果系统时间和设置的时间相同,则播报
    if(ui->textEdit->toPlainText() == ui->label->text())
    {
            speech->say(ui->textEdit_2->toPlainText());
    }
}

//启动按钮对应的槽函数
void Widget::on_pushButton_clicked()
{
    //执行启动功能,开启闹钟功能,不可编辑
    ui->textEdit->setDisabled(true);
    ui->textEdit_2->setDisabled(true);
    //将关闭按钮设置成不响应状态
    ui->pushButton_2->setDisabled(false);
    //将启动按钮设置成响应状态
    ui->pushButton->setDisabled(true);

}

//关闭按钮对应的槽函数
void Widget::on_pushButton_2_clicked()
{
    //执行关闭功能,停止播报
    speech->stop();
    ui->textEdit->setDisabled(false);
    ui->textEdit_2->setDisabled(false);
    //将关闭按钮设置成响应状态
    ui->pushButton_2->setDisabled(true);
    //将启动按钮设置成不响应状态
    ui->pushButton->setDisabled(false);
}

 运行效果:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
api.map.baidu.com是百度地图API的网址。百度地图API是一种基于QT开发的地图应用程序编程接口,旨在为开发者提供一系列的地图相关功能和数据。通过调用这个API,开发者可以在自己的应用程序中嵌入地图功能,实现地图显示、地理位置搜索、路线规划、交通状况查询等多种功能。 使用api.map.baidu.com qt,开发者可以借助QT框架和百度地图API实现高度个性化和可交互的地图应用程序。QT是一种跨平台的应用程序开发框架,提供了丰富的界面组件和功能模块,使得开发者可以快速构建功能强大的应用程序。结合百度地图API,开发者可以轻松实现地图界面的展示和交互,同时还可以根据自身需求添加更多的功能,如标记地点、显示路线、查询周边信息等。 通过api.map.baidu.com qt,开发者可以利用QT框架的优势,如良好的可扩展性和可定制性,来创建各种类型的地图应用程序。无论是基于桌面的地图应用,还是针对移动设备(如智能手机和平板电脑)的地图应用,这个组合都可以提供出色的性能和用户体验。此外,百度地图API还提供了强大的地理数据和服务,开发者可以根据实际需求来获取和利用这些数据,以进一步丰富和优化应用程序的功能。 总而言之,api.map.baidu.com qt提供了一种强大而灵活的方式,使得开发者可以轻松地在自己的应用程序中集成地图功能,并且根据需求进行个性化定制,以实现更多样化和功能丰富的地图应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值