您好,登錄后才能下訂單哦!
怎么在pyqt5中利用ComboBox實現一個鼠標點擊觸發事件?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
# 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()
# test_ui.py self.PrintersList = MyComboBox(self.groupBox) # 修改后 # self.PrintersList = QtWidgets.QComboBox(self.groupBox) # 修改前
# 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)
關于怎么在pyqt5中利用ComboBox實現一個鼠標點擊觸發事件問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。