实现一个闹钟界面,这个界面包括(启动按钮pushButton、关闭按钮pushButton_2、显示系统时间的label、显示用户设定时间的lineEdit、还有一个语音播报文本框textEdit)

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include<QTimer>//定时器类
#include<QTime> //时间类(用来获取时间)
#include<QTimerEvent>//定时器事件类
#include<QTextToSpeech>
#include<cstring>

#include <QDebug>


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_pushButton_clicked();//启动按钮

    void updateClock(); // 更新时钟的槽函数

    void on_pushButton_2_clicked();//关闭按钮



    //void timerEvent(QTimerEvent *event)override;//重写定时器事件处理函数

private:
    Ui::Widget *ui;
    //使用定时器类,定义一个闹钟
    QTimer *timer;
     //语音播报
     QTextToSpeech * my_speech;
};
#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);
    // 创建定时器对象并启动
    timer = new QTimer(this);
    connect(timer, SIGNAL(timeout()), this, SLOT(updateClock()));
    timer->start(1000); // 每隔1秒更新一次

    // 创建文本转语音对象
    my_speech= new QTextToSpeech(this);

    // 连接按钮的信号和槽函数
    connect(ui->pushButton, SIGNAL(clicked()), this, SLOT(on_pushButton_clicked()));
    connect(ui->pushButton_2, SIGNAL(clicked()), this, SLOT(on_pushButton_2_clicked()));
    // 创建定时器并连接到更新时钟的槽函数
    timer = new QTimer(this);
    connect(timer, &QTimer::timeout, this, &Widget::updateClock);
    //设定定时器的时间间隔为1s并启动它
    timer->start(1000);

}




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

//启动按钮对应的槽函数
void Widget::on_pushButton_clicked()
{
    //启动定时器
    ui->pushButton_2->setEnabled(true);
    ui->pushButton->setEnabled(false);
    timer->start(1000);


}

// 更新时钟的槽函数
void Widget::updateClock()
{
    //获取当前时间,并且显示在标签上
    QTime time=QTime::currentTime();
    QString timeStr=time.toString("hh:mm:ss");
    ui->label->setText(timeStr);
    if(timeStr==ui->lineEdit->text())
    {
        qDebug()<<"sadadaw";
    }

}
//关闭按钮对应的槽函数
void Widget::on_pushButton_2_clicked()
{
    //停止定时器
    timer->stop();
    ui->pushButton_2->setEnabled(false);
    ui->pushButton->setEnabled(true);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要在PyQt5中创建一个窗口并添加一个PushButton按钮和两个Label标签。一个Label标签用于显示摄像头捕获的图像,另一个用于显示拍摄的图像。 其次,你需要使用OpenCV库来捕获摄像头的图像。在点击PushButton按钮时,你需要触发一个事件来捕获图像并将其保存为图像文件。 最后,你需要将拍摄的图像加载到第二个Label标签上。以下是示例代码: ```python import sys import cv2 from PyQt5.QtCore import pyqtSlot from PyQt5.QtGui import QImage, QPixmap from PyQt5.QtWidgets import QApplication, QDialog, QLabel, QPushButton from PyQt5.uic import loadUi class CameraUI(QDialog): def __init__(self): super(CameraUI, self).__init__() loadUi('camera.ui', self) # 加载UI文件 self.image_label.setScaledContents(True) # 让标签自适应图片大小 self.capture = cv2.VideoCapture(0) # 打开摄像头 @pyqtSlot() def start_camera(self): while True: ret, frame = self.capture.read() # 读取摄像头图像 if ret: self.display_image(frame, 1) # 在第一个标签上显示摄像头图像 cv2.waitKey(30) else: break @pyqtSlot() def capture_image(self): ret, frame = self.capture.read() # 读取摄像头图像 if ret: self.display_image(frame, 2) # 在第二个标签上显示拍摄的图像 cv2.imwrite("capture.jpg", frame) # 保存拍摄的图像 cv2.waitKey(30) def display_image(self, img, window=1): qformat = QImage.Format_Indexed8 if len(img.shape) == 3: if img.shape[2] == 4: qformat = QImage.Format_RGBA8888 else: qformat = QImage.Format_RGB888 img = QImage(img, img.shape[1], img.shape[0], qformat) img = img.rgbSwapped() if window == 1: self.image_label.setPixmap(QPixmap.fromImage(img)) self.image_label.setAlignment(QtCore.Qt.AlignHCenter | QtCore.Qt.AlignVCenter) else: self.image_label_2.setPixmap(QPixmap.fromImage(img)) self.image_label_2.setAlignment(QtCore.Qt.AlignHCenter | QtCore.Qt.AlignVCenter) if __name__ == '__main__': app = QApplication(sys.argv) window = CameraUI() window.show() sys.exit(app.exec_()) ``` 其中,camera.ui是PyQt5 Designer创建的UI文件,包含一个MainWindow窗口、两个Label标签和两个PushButton按钮。start_camera()和capture_image()方法分别用于显示摄像头图像和拍摄图像,并将其显示在两个标签上。display_image()方法用于将OpenCV捕获的图像显示在标签上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值