PyQT5关于界面操作有感

PyQT5关于界面操作有感

最近使用PyQt5中的QTableWidget做一些表格显示信息,需要根据实时接收的报文信息动态的更新界面,实现之后发现,只有点击界面是才会出现界面的刷新,从网上查了一些资料,都是建议使用多线程进行更新,但是我本来就是使用的多线程接收反馈信息进行更新的,后来猜测还需要使用信号与槽来触发更新,而不是直接设置界面的属性,关于更进一步的原理暂时还不清楚,但是之前实时打印QTextEdit内的信息时,也是多线程+信号与槽才最终完成的,不然程序运行一会儿挂掉。所以目前猜测,关于界面的信息属性调整,最好还是通过信号与槽的方式触发更新,而不是直接调用函数更新,关于具体的原理,希望有了解的小伙伴可以分享一下。
以下分享以下信号与槽的使用方法,用于提醒自己以后关于此类操作的套路:

from PyQt5.QtCore import pyqtSignal
class Table(QWidget):
	updata_signal=pyqtSignal(int,str)     #此处创建一个信号
	self.updata_signal.connect(self.change_color)   #绑定信号与槽函数
	#下面定义一个槽函数,参数row指需要修改行的位置,参数color指的时需要修改的颜色
	def change_color(self,row,color):
		if color=='green':
            for c in range(0, 8):     #此处循环是因为表格中每行都有8列,想把每个单元格的颜色都修改
                self.TableWidget.item(row, c).setBackground(QBrush(QColor(0, 175, 0)))
        elif color=='white':
            for c in range(0, 8):
                self.TableWidget.item(row, c).setBackground(QBrush(QColor(255, 255, 255)))
        else:
            print('选择改变颜色失败',row)
win=Table()
win.updata_signal.emit(2, 'green')  #此处用于触发槽函数

以上代码不可直接拿来使用,写此文章目的是为了提醒自己,以后遇到此类事情的处理思路。目前调用的多线程是python自带的Threading,并没有使用QThread,目前没遇到问题,后续可以关注下两者对于GUI的处理是否有较大区别。

图像去噪是一种常见的图像处理技术,可以帮助消除图像中的噪声,提高图像的质量。而PyQt5则是一种基于Python语言的GUI编程工具,可以用来设计和开发图形化界面。在PyQt5中,我们可以通过使用QImage和QPixmap等类来加载和显示图像,同时也可以使用各种滤波器来实现图像去噪。 以下是一个简单的图像去噪操作界面的示例: ```python import sys from PyQt5.QtWidgets import QApplication, QMainWindow, QLabel, QPushButton, QFileDialog from PyQt5.QtGui import QImage, QPixmap from PyQt5.QtCore import Qt import cv2 class MainWindow(QMainWindow): def __init__(self): super().__init__() # 创建标签和按钮 self.label = QLabel(self) self.label.setAlignment(Qt.AlignCenter) self.btn_open = QPushButton('打开图片', self) self.btn_open.clicked.connect(self.open_image) self.btn_denoise = QPushButton('去噪', self) self.btn_denoise.clicked.connect(self.denoise_image) # 创建布局 central_widget = QLabel(self) layout = QVBoxLayout(central_widget) layout.addWidget(self.label) layout.addWidget(self.btn_open) layout.addWidget(self.btn_denoise) self.setCentralWidget(central_widget) def open_image(self): # 打开图片并显示 file_path, _ = QFileDialog.getOpenFileName(self, '打开图片', '.', 'Image Files (*.jpg *.png *.bmp)') if file_path: image = cv2.imread(file_path) image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB) h, w, c = image.shape bytesPerLine = c * w q_image = QImage(image.data, w, h, bytesPerLine, QImage.Format_RGB888) pixmap = QPixmap.fromImage(q_image) self.label.setPixmap(pixmap) def denoise_image(self): # 对图片进行去噪处理 pixmap = self.label.pixmap() if pixmap is not None: image = pixmap.toImage() w, h = image.width(), image.height() ptr = image.bits() ptr.setsize(image.byteCount()) arr = np.array(ptr).reshape(h, w, 4)[:, :, :3] arr = cv2.fastNlMeansDenoisingColored(arr, None, 10, 10, 7, 21) q_image = QImage(arr.data, w, h, arr.strides, QImage.Format_RGB888) pixmap = QPixmap.fromImage(q_image) self.label.setPixmap(pixmap) if __name__ == '__main__': app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值