我的实际应用程序比这个复杂得多,但是下面的例子总结了我的大部分问题。我有多个qlabel,我已经子类化了它们,使它们可以单击。标签显示16x16个图像,这需要一个过程,通过枕头加载图像,将其转换为ImageQt对象,然后设置标签的pixmap。在本例中,我有3个可单击的qlabel,它们在每次单击它们时都会运行print_something函数。我的目标是能够按住鼠标,并且对于我悬停的每个标签,函数都会被调用。任何建议都很好。在
from PyQt5 import QtCore, QtWidgets, QtGui
from PIL import Image
from PIL.ImageQt import ImageQt
import sys
class ClickableLabel(QtWidgets.QLabel):
def __init__(self):
super().__init__()
clicked = QtCore.pyqtSignal()
def mousePressEvent(self, ev):
if app.mouseButtons() & QtCore.Qt.LeftButton:
self.clicked.emit()
class MainWindow(QtWidgets.QMainWindow):
def __init__(self):
super().__init__()
central_widget = QtWidgets.QWidget()
self.setFixedSize(300, 300)
image = Image.open("16x16image.png")
image_imageqt = ImageQt(image)
hbox = QtWidgets.QHBoxLayout()
hbox.setSpacing(0)
hbox.addStretch()
label01 = ClickableLabel()
label01.setPixmap(QtGui.QPixmap.fromImage(image_imageqt))
label01.clicked.connect(self.print_something)
hbox.addWidget(label01)
label02 = ClickableLabel()
label02.setPixmap(QtGui.QPixmap.fromImage(image_imageqt))
label02.clicked.connect(self.print_something)
hbox.addWidget(label02)
label03 = ClickableLabel()
label03.setPixmap(QtGui.QPixmap.fromImage(image_imageqt))
label03.clicked.connect(self.print_something)
hbox.addWidget(label03)
hbox.addStretch()
central_widget.setLayout(hbox)
self.setCentralWidget(central_widget)
def print_something(self):
print("Printing something..")
if __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv)
main_window = MainWindow()
main_window.show()
sys.exit(app.exec_())
问题的原因在QMouseEvent的文档中说明:
似乎没有一个简单的方法来解决这个问题,所以需要一些黑客的东西。一个想法是启动一个假拖动,然后使用}。类似这样的方法可能会奏效:
dragEnterEvent
而不是{相关问题 更多 >
编程相关推荐