基于Python3和pyqt5实现控件数据动态显示

最近笔者在做一个pyqt5的界面,由于在日常生活中,一些实际运用的场合都需要对数据进行实时的刷新,例如对某个数值的监控,水温,室温的监控等等,都需要实时的刷新控件显示的数据。
对于实现这样的一种功能,pyqt5在面板生成的同时就固定住了UI中的数据,例如我们产生一个QLineEdit控件,然后布局在面板上,但是控件中的数据是固定的,如果这个数据是实时更新的,想要改变空间中的数据时,就要去刷新面板,pyqt5提供了一个QApplication.processEvents()的命令来刷新整个面板,但是要完成数据的动态显示,则要不断的去调用这个函数来刷新面板,同样,以使用多线程去刷新面板上的数据,但是通过搜索各种大佬的博客等,发现了pyqt5多线程刷新的各种问题,即大佬主要使用多线程来对控件显示的数据进行实时的刷新。 本文旨在演示一种使用定时器来刷新控件实现数据的方法,具体代码如下:

import sys
import random
import numpy as np
from time import sleep
import datetime
from PyQt5 import QtWidgets
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

定义数据生成线程,该线程主要目的是不断生成随机数,用来模拟不断采集数据

class WorkThread(QThread):
    # 初始化线程
    def __int__(self):
        super(WorkThread, self).__init__()
    #线程运行函数
    def run(self):
        while True:
            global T_value
            global P_value
            T_value = random.randint(200,225)
            P_value = random.randint(150,200)
            print(T_value, P_value)
            sleep(3)

定义显示面板

class plotwindows(QtWidgets.QWidget):
    def __init__(self):
        super(plotwindows,self).__init__()
        layout = QFormLayout()
        self.edita3 = QLineEdit()
        self.edita4 = QLineEdit()
        self.edita5 = QLineEdit()
        layout.addRow("A数值", self.edita3)
        layout.addRow("B数值", self.edita4)
        layout.addRow("C数值", self.edita5)
        self.setLayout(layout)
        self.Mytimer()

定义定时器,使用定时器每隔一段时间来出发update函数,从而刷新数据

def Mytimer(self):
    timer = QTimer(self)
    timer.timeout.connect(self.update)
    timer.start(100)

刷新函数

def update(self):
   self.edita3.setText(str(T_value))
    self.edita4.setText(str(P_value))
    global SUM_value
    SUM_value = T_value + P_value
    self.edita5.setText(str(SUM_value))

def mainwindows():
    app =QtWidgets.QApplication(sys.argv)
    new = plotwindows()
    new.show()
    sys.exit(app.exec_())

if __name__ == "__main__":
    workThread = WorkThread()
    workThread.start()
    mainwindows()

在这里插入图片描述
在这里插入图片描述
可以看到,子线程不断的生成数据,同时定时器以一种不断调用刷新函数的方法来实现对控件显示数据的刷新,这样就不用再建立新线程的情况下实现刷新控件显示的功能。
如有不足,请多指教。。。

  • 19
    点赞
  • 147
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
以下是一个基本的使用PyQt5实现动态人脸识别界面的代码示例。 ```python from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import * import cv2 class FaceDetectionThread(QThread): face_detected = pyqtSignal(QImage) def __init__(self, parent=None): super(FaceDetectionThread, self).__init__(parent) self.classifier = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') self.video_capture = cv2.VideoCapture(0) def run(self): while True: ret, frame = self.video_capture.read() if ret: gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) faces = self.classifier.detectMultiScale(gray, 1.3, 5) for (x, y, w, h) in faces: cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2) rgb_image = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB) h, w, ch = rgb_image.shape bytes_per_line = ch * w convert_to_qt_format = QImage(rgb_image.data, w, h, bytes_per_line, QImage.Format_RGB888) p = convert_to_qt_format.scaled(640, 480, Qt.KeepAspectRatio) self.face_detected.emit(p) class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle('Face Detection') self.image_label = QLabel(self) self.image_label.setMinimumSize(640, 480) self.setCentralWidget(self.image_label) self.face_detection_thread = FaceDetectionThread() self.face_detection_thread.face_detected.connect(self.show_image) self.face_detection_thread.start() def show_image(self, image): self.image_label.setPixmap(QPixmap.fromImage(image)) if __name__ == '__main__': import sys app = QApplication(sys.argv) main_window = MainWindow() main_window.show() sys.exit(app.exec_()) ``` 在此示例中,我们使用OpenCV库进行人脸检测,并将检测到的人脸绘制到图像上。然后,我们将图像转换为Qt中的QImage格式,并在PyQt5中显示它。 在主窗口中,我们创建一个QLabel对象,并将其设置为中央控件。我们还创建一个FaceDetectionThread对象,该对象负责在后台运行人脸检测。当检测到人脸时,我们使用show_image方法将图像显示在标签上。最后,我们启动了主应用程序循环并显示主窗口。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值