qpython3编程开发工具_Python3与PyQt5编程示例:实现颜色拾取器小工具

本文介绍如何使用Python的PyQt5库创建一个颜色拾取器工具,该工具能实时显示鼠标所在位置的颜色信息,包括RGB和CSS值。通过定时器获取鼠标位置,利用QScreen和QCursor获取颜色值,简洁的代码实现高效的功能,对比C++等语言,Python+PyQt更显便捷。
摘要由CSDN通过智能技术生成

对于基于Python+PyQt的框架结构的程序开发,前面已经讲了很多小例子了,有兴趣的小伙伴们可以翻看下前面的文章。

总体来说,实现相同的功能,相比于其它如C/C++等编程语言,确实简单太多了。

下面,再给出一个小例子,使用PyQt5界面库,在Python3上来实现一个简单的颜色拾取器的小工具,下面看看具体的实现过程吧。

1、实例说明

本例运行界面如下图所示,实现的功能是,实时捕捉当前鼠标所在位置的颜色并进行显示,显示结果包括颜色指示、颜色的RGB值、颜色的CSS值及当前鼠标的坐标值等信息。

6597338_202001171535230849906459_wm.jpg

2、实现思路

可考虑在定时器超时事件中每隔一段时间(如20ms)取一次当前鼠标所在的位置的颜色信息,对该颜色值进行解析并分别显示其RGB值和CSS样式的值。

在PyQt中进行编程实现时,需要考虑以下两个问题:

如何取当前鼠标的位置信息?

如何获取当前位置的颜色值并将其分解为RGB值和CSS值?

对于第一个问题,可使用PyQt类中的QCusor类的pos()函数实时获取当前的鼠标位置信息。

对于第二个问题,可使用QScreen类的grabWindow()函数,将当前鼠标所在区域存储为QPixmap类型的画布里面,然后再使用toImage()函数将其转化为图像,有了图像信息后,就可获取该图像上任意像素点的颜色信息(QColor类型)了。最后使用QColor类的red()、green()、blue()函数分别获取其RGB值即可。对于颜色的CSS值显示,直接将RGB值转换为16进制显示即可。

3、核心代码实现

在定时器超时槽函数里面实现该软件的具体功能,其代码(不足20行)如下图所示:

6597338_202001171535370849948893_wm.jpg

代码简要解释如下:

(1)第48-50行,使用QCusor类的pos()函数获取当前的鼠标位置信息x、y并显示。

(2)第52-56行,使用QScreen类的grabWindow()函数,将当前鼠标所在区域存储到QPixmap类型的pixmap变量里面,使用toImage()函数将其转化为图像,然后使用pixel()函数获取该图像上(0,0)像素点的颜色信息,最后使用QColor类的red()、green()、blue()函数分别获取其RGB颜色的分量值。

(3)第58-60行,将RGB颜色进行显示,并在label控件上使用样式表设置其背景色进行实时指示当前鼠标所在位置的颜色信息。

(4)第62-64行,将R、G、B颜色值转换为16进制,显示其CSS值信息。

4、完整代码实现

整个工程除了上面的核心代码实现外,还包括界面的布局、定时器创建、槽函数关联等内容,程序的完整实现代码如下图所示:

6597338_202001171535560599440277_wm.jpg

程序主窗口基类为QWidget类,代码简要解释如下:

(1)第9-14行,类初始化函数,调用initUI函数并创建定时器、设置槽函数关联及启动定时器等。

(2)第16-40行,具体的界面设计函数,包括控件的创建/布局、窗口的居中设置、标题、图标设置等。

(3)第61-65行,创建窗口并显示。

5、总结

总体来说,这个例子界面比较简单,代码量比较少,也比较好理解,运行上面的程序后,即可出现前面的软件界面,当移动鼠标时,可在界面上实时显示当前鼠标位置的颜色信息。

本文实现颜色拾取器的小工具,仅仅用了不到70行的代码,试想一下,如果你用纯粹的C++语言来实现相同的功能,将需要多少代码量呢?所以,如果你做软件界面开发的话,Python+PyQt的框架结构真的是一个不错的选择。

本文由编码那些事原创,请关注+转发+收藏+点赞,带你一起长知识!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是使用Python3+PyQT5+Pyserial实现简单的串口工具方法的示例代码: ``` python import sys import serial from PyQt5.QtWidgets import QApplication, QMainWindow, QTextEdit, QAction, QFileDialog from PyQt5.QtCore import QThread, pyqtSignal class SerialThread(QThread): received = pyqtSignal(str) def __init__(self, port, baudrate): super().__init__() self.port = port self.baudrate = baudrate self.serial = None def run(self): try: self.serial = serial.Serial(self.port, self.baudrate) while True: data = self.serial.readline().decode("utf-8") if data: self.received.emit(data) except Exception as e: print(e) def write(self, data): if self.serial: self.serial.write(data.encode("utf-8")) def close(self): if self.serial: self.serial.close() class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle("Serial Tool") self.setGeometry(100, 100, 800, 600) self.text_edit = QTextEdit(self) self.text_edit.setReadOnly(True) self.setCentralWidget(self.text_edit) open_action = QAction("Open", self) open_action.setShortcut("Ctrl+O") open_action.triggered.connect(self.open_file) self.menuBar().addAction(open_action) self.thread = SerialThread("COM1", 115200) self.thread.received.connect(self.append_text) self.thread.start() def append_text(self, text): self.text_edit.moveCursor(QtGui.QTextCursor.End) self.text_edit.insertPlainText(text) def open_file(self): file_name, _ = QFileDialog.getOpenFileName(self, "Open File", "", "Text Files (*.txt)") if file_name: with open(file_name, "r") as f: data = f.read() self.thread.write(data) def closeEvent(self, event): self.thread.close() event.accept() if __name__ == "__main__": app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) ``` 这个示例代码实现了一个简单的串口工具,可以实现打开串口、读取串口数据、发送数据等功能。其中SerialThread类用于在后台线程中读取串口数据,MainWindow类用于创建窗口并处理窗口事件。该代码可以根据需要进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值