Слот не работает для QListWidget itemClicked (pyqt)
Я создаю QListWidget и хочу подключить элемент, щелкнувший по моему слоту. И следующий код в порядке: когда я нажимаю на элемент, вызывается список виджетов
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
import sys
class MainWindow(QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.imagelabel = QLabel()
layout = QVBoxLayout()
self.imagelabel.setLayout(layout)
self.setCentralWidget(self.imagelabel)
label1 = QLabel('hello, world')
layout.addWidget(label1)
newlistWidget = QListWidget()
newlistWidget.addItem(QListWidgetItem('item3'))
newlistWidget.addItem(QListWidgetItem('item4'))
layout.addWidget(newlistWidget)
newlistWidget.itemClicked.connect(self.listwidgetclicked)
def listwidgetclicked(self):
print('click')
app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec_()
Тем не менее, я хочу собрать весь код GUI вместе. Поэтому я создаю класс и соединяю сигнал и слот в этом классе. Когда я щелкаю по элементу, щелчок по списку не работает, и код:
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
import sys
class GUI(QObject):
def __init__(self):
super(GUI, self).__init__()
self.layout = QVBoxLayout()
self.initGUI()
def getLayout(self):
return self.layout
def initGUI(self):
self.listWidget = QListWidget()
self.listWidget.addItem(QListWidgetItem('item1'))
self.listWidget.addItem(QListWidgetItem('item2'))
self.listWidget.itemClicked.connect(self.listwidgetclicked)
self.layout.addWidget(self.listWidget)
def listwidgetclicked(self, item):
print('click')
class MainWindow(QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.imagelabel = QLabel()
layout = QVBoxLayout()
self.imagelabel.setLayout(layout)
self.setCentralWidget(self.imagelabel)
label1 = QLabel('hello, world')
layout.addWidget(label1)
listWidget = GUI()
layout.addLayout(listWidget.getLayout())
app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec_()
Я не знаю, в чем разница между двумя кодами.
1 ответ
Решение
Попытайся:
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
class GUI(QListWidget):
def __init__(self):
super(GUI, self).__init__()
self.layout = QVBoxLayout()
self.initGUI()
# def getLayout(self):
# return self.layout
def initGUI(self):
# self.listWidget = QListWidget()
self.addItem(QListWidgetItem('item1'))
self.addItem(QListWidgetItem('item2'))
self.itemClicked.connect(self.listwidgetclicked)
self.layout.addWidget(self) #.listWidget)
def listwidgetclicked(self, item):
print('!!! click {}'.format(item.text()))
class MainWindow(QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.imagelabel = QLabel()
layout = QVBoxLayout()
self.imagelabel.setLayout(layout)
self.setCentralWidget(self.imagelabel)
label1 = QLabel('hello, world')
layout.addWidget(label1)
listWidget = GUI()
# layout.addLayout(listWidget.getLayout()) # ---
layout.addWidget(listWidget) # +++
app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec_()
Обновить:
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
import sys
class GUI(QObject):
def __init__(self):
super(GUI, self).__init__()
self.layout = QVBoxLayout()
self.initGUI()
def getLayout(self):
return self.layout
def initGUI(self):
self.listWidget = QListWidget()
self.listWidget.addItem(QListWidgetItem('item1'))
self.listWidget.addItem(QListWidgetItem('item2'))
self.listWidget.itemClicked.connect(self.listwidgetclicked)
self.layout.addWidget(self.listWidget)
def listwidgetclicked(self, item):
print('click -> {}'.format(item.text()))
class MainWindow(QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.imagelabel = QLabel()
layout = QVBoxLayout()
self.imagelabel.setLayout(layout)
self.setCentralWidget(self.imagelabel)
label1 = QLabel('hello, world')
layout.addWidget(label1)
self.listWidget = GUI() # <--- + self.
layout.addLayout(self.listWidget.getLayout()) # <--- + self.
app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec_()