使用pyqt5 实现ComboBox的鼠标点击触发事件
作者:Jan___ 发布时间:2022-01-12 17:24:57
标签:pyqt5,ComboBox,鼠标,触发事件
一、自定义MyComboBox
# MyComboBox.py
from PyQt5.QtWidgets import QComboBox
from PyQt5.QtCore import pyqtSignal
class MyComboBox(QComboBox):
clicked = pyqtSignal() #创建一个信号
def showPopup(self): #重写showPopup函数
self.clicked.emit() #发送信号
super(MyComboBox, self).showPopup() # 调用父类的showPopup()
二、使用MyComboBox创建窗口空间
# test_ui.py
self.PrintersList = MyComboBox(self.groupBox) # 修改后
# self.PrintersList = QtWidgets.QComboBox(self.groupBox) # 修改前
三、main函数中对clicked 信号进行绑定
# main_loop.py
self.PrintersList.clicked.connect(self.scan_printer_list_slot) # 信号与槽函数的绑定
# 槽函数的实现
def scan_printer_list_slot(self):
print("扫描打印机并刷新列表")
补充:PyQt5中QComboBox实现多选功能
网上大佬太多了,写的啥没看懂,自己摸索着也写了个出来,也勉强能用。
功能:
QComboBox实现多选功能
返回选中的文本列表
一键全选和取消全选功能
from PyQt5 import QtCore, QtGui, QtWidgets
import sys
class CheckableComboBox(QtWidgets.QComboBox):
def __init__(self, parent=None):
super(CheckableComboBox, self).__init__(parent)
self.setModel(QtGui.QStandardItemModel(self))
self.view().pressed.connect(self.handleItemPressed)
self.checkedItems = []
self.view().pressed.connect(self.get_all)
self.view().pressed.connect(self.getCheckItem)
self.status = 0
def handleItemPressed(self, index): #这个函数是每次选择项目时判断状态时自动调用的,不用管(自动调用)
item = self.model().itemFromIndex(index)
if item.checkState() == QtCore.Qt.Checked:
item.setCheckState(QtCore.Qt.Unchecked)
else:
item.setCheckState(QtCore.Qt.Checked)
def getCheckItem(self):
# getCheckItem方法可以获得选择的项目列表,自动调用。
for index in range(1,self.count()):
item = self.model().item(index)
if item.checkState() == QtCore.Qt.Checked:
if item.text() not in self.checkedItems:
self.checkedItems.append(item.text())
else:
if item.text() in self.checkedItems:
self.checkedItems.remove(item.text())
print("self.checkedItems为:",self.checkedItems)
return self.checkedItems #实例化的时候直接调用这个self.checkedItems就能获取到选中的值,不需要调用这个方法,方法会在选择选项的时候自动被调用。
def get_all(self): #实现全选功能的函数(自动调用)
all_item = self.model().item(0)
for index in range(1,self.count()): #判断是否是全选的状态,如果不是,全选按钮应该处于未选中的状态
if self.status ==1:
if self.model().item(index).checkState() == QtCore.Qt.Unchecked:
all_item.setCheckState(QtCore.Qt.Unchecked)
self.status = 0
break
if all_item.checkState() == QtCore.Qt.Checked:
if self.status == 0 :
for index in range(self.count()):
self.model().item(index).setCheckState(QtCore.Qt.Checked)
self.status = 1
elif all_item.checkState() == QtCore.Qt.Unchecked:
for index in range(self.count()):
if self.status == 1 :
self.model().item(index).setCheckState(QtCore.Qt.Unchecked)
self.status = 0
if __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv)
dialog = QtWidgets.QMainWindow()
mainWidget = QtWidgets.QWidget()
dialog.setCentralWidget(mainWidget)
ComboBox = CheckableComboBox(mainWidget)
ComboBox.addItem("全选")
for i in range(6):
ComboBox.addItem("Combobox Item " + str(i))
dialog.show()
sys.exit(app.exec_())
总结(用法):
直接实例化一个Qcombox
使用ComboBox.addItem方法添加项目
调用ComboBox.checkedItems的属性就能获取到选中的文本列表
内置函数基本都是自动的,统统不用管
调用checkedItems属性的时候最后写在ComboBox的槽函数里,这样才能获取到更改后的属性,不然可能得到的会是空值。
补充:
定义一个槽函数self.get_checkedItems_slot用于获取更改后的checkedItems属性,下面三种ComboBox的信号槽选一种来用就行,推荐第一种。
ComboBox.activated.connect(self.get_checkedItems_slot) #推荐
ComboBox.highlighted.connect(self.get_checkedItems_slot)
ComboBox.currentIndexChanged.connect(self.get_checkedItems_slot)
挺不容易的,网上资料有关Pyqt太少了,要么是Qt的,要么写得太复杂,要么没讲解的,大多是靠自己摸索出来的。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
来源:https://blog.csdn.net/mynameisJW/article/details/109396226
![](https://www.aspxhome.com/images/zang.png)
![](https://www.aspxhome.com/images/jiucuo.png)
猜你喜欢
- 介绍在Python语言中最常见的括号有三种,分别是:小括号()、中括号[]、花括号{};其作用也不相同,分别用来代表不同的Python基本内
- 工作中每天需要收集部门内的FR文件,发送给外部部门的同事帮忙上传,这么发了有大半年,昨天亮光一闪,为什么不做成自动化呢,于是用python实
- 美化主要表现在鼠标放到菜单上后(即鼠标悬停)的效果,这里首先介绍几个经常用到的CSS属性:backgr
- 在SQL Server中进行开发会让你身处险地,并且寻找快速解决方案。我们编辑了前十名关于SQL Server开发的常见问题。对常见的针对表
- asp之家注:在网页设计或编程中如何以最方便的方法来处理图片的宽高,以达到最佳的显示效果,这个问题相信很多网页制作人员都遇到过,最麻烦最费时
- 列表生成式语法:[x*x for x in range(0,10)] //列表生成式,这里是中括号//结果 [0, 1, 4, 9, 16,
- Sequence Typessequence类型有六种:strings, byte sequences (bytes objects), b
- 前言最近在开发项目时遇到了发现一个问题,gorm虽然可以自动帮你维护 created_at、updated_at、deleted_at这些关
- 内容摘要: Request和Response这两个对象是ASP所提供的内置对象中最常用的两个。在浏览器(或其他用户代理)和Web服
- 这篇文章主要介绍了原生Java操作mysql数据库过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要
- mysql是linux平台下最流行的数据库系统,今天介绍的是mysql的安装及简单的操作方法!groupadd mysql //建立mysq
- Python中编码问题:u'\xe6\x97\xa0\xe5\x90\x8d' 类型的转为utf-8的解决办法相信小伙伴们遇
- 如何同时处理数据库和页面错误? If Err.Number = 0 And ob
- 前言猪年除夕之夜在亲人群抢红包心血来潮,想用python做比较好玩的新年祝福给亲人们乐呵乐呵。奈何初学Python,底子比较薄,通过查阅相关
- 使用Django意味着后台框架的几乎所有内容都会和Django产生互动,排除功能全部手撸的情况.Django 后台admin有大量的属性和方
- asp生成wbmp代码如下: <%@ Language=VBScript %><%Funct
- 使用Python进行插值非常方便,可以直接使用scipy中的interpolateimport numpy as npx1 = np.lin
- PyTorch与PyTorch Geometric的安装GPU与CUDA,Python,PyTorch的匹配1. 查看Linux系统中GPU
- CREATE TABLE table1( [ID] [bigint] IDENTITY(1,1) NOT NULL, [Name] [nva
- 1 解决方案【方案一】载入模型结构放在全局,即tensorflow会话外层。'''载入模型结构:最关键的一步'