使QLabel可点击

5

我有一个用QPixmap填充的Qlabel,并且希望在该标签被点击后启动一个进程/函数。我已经扩展了QLabel类如下:

from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class QLabel_alterada(QLabel):
  clicked=pyqtSignal()
  def __init(self, parent):
    QLabel.__init__(self, QMouseEvent)

  def mousePressEvent(self, ev):
    self.clicked.emit()

然后,在基于pyuic5的.py文件中(我使用QtDesigner进行布局),在导入保存扩展QLabel类的模块后,我在自动生成的setupui函数中将标签从以下内容更改:

self.label1=QtWidgets.QLabel(self.centralwidget)

为了

self.label1 = QLABEL2.QLabel_alterada(self.centralwidget)

最后,在核心应用程序的Python文件中,我添加了所有必要的过程/类以实现应用程序的功能。

self.ui.label1.clicked.connect(self.dosomestuff) 

应用程序没有崩溃,但标签仍然无法点击。有人能帮我解决这个问题吗?

我已经发布了一个答案,但如果不够的话,您可以提供QtDesigner生成的代码,在那里进行了修改。 - eyllanesc
谢谢@eyllanesc。它仍然无法点击。我在QtDesigner生成的代码中进行了唯一的更改,即将我想要转换为“可点击”的Qlabel对象。我在我的帖子中提到了这个变化。您认为它是否与“self.centralWidget”作为QLabel_alterada类的参数有关吗? - Francisco Cunha
是的,你可以做到,我认为错误在其他地方,所以我请你提供QtDesigner生成的代码,以便查看你所做的更改。 - eyllanesc
@eyllanesc 我有一个独特的文件夹,其中包含由pyuic生成的代码的.py文件和包含核心应用程序的文件。这个文件夹还包含我保存QLabel扩展类的文件。QtDesigner中的代码非常庞大,包括所有的setobjectnames、addwidgets、addlayouts等等,这些都是qtdesigner+pyuic自动处理的。 - Francisco Cunha
你的代码对我来说是有效的,只需添加颜色以便您可以看到要单击的位置。 - eyllanesc
显示剩余7条评论
4个回答

9

我不明白为什么要将QMouseEvent传递给父类构造函数,你必须按照下面所示传递父属性:

class QLabel_alterada(QLabel):
    clicked=pyqtSignal()

    def mousePressEvent(self, ev):
        self.clicked.emit()

为了避免导入时出现问题,我们可以直接将小部件(widget)提升,具体步骤如下:
首先在界面中放置一个 QLabel,然后右键点击并选择“提升为...”。
会弹出对话框,将 QLABEL2.h 添加到头文件中,将 QLabel_changed 添加到“提升类名称”中,然后按下“添加”和“提升”按钮。
最后,我们使用 pyuic 去生成 .ui 文件,获取以下结构:
├── main.py
├── QLABEL2.py
└── Ui_main.ui

获得以下结构:
class MainWindow(QtWidgets.QMainWindow):
    def __init__(self, parent=None):
        QtWidgets.QMainWindow.__init__(self, parent)
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        self.ui.label.clicked.connect(self.dosomestuff) 

    def dosomestuff(self):
        print("click")


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    w = MainWindow()
    w.show()
    sys.exit(app.exec_())

4

由于Python可以将函数作为对象传递,我认为仅继承QLabel使其可点击的做法过于复杂。相反,我会像这样做:

import sys

from PyQt5 import QtWidgets
from PyQt5.QtWidgets import QFrame, QLabel


def foo(*arg, **kwargs):
   print("Bar")


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    Frame = QFrame()
    label = QLabel(Frame)
    label.mousePressEvent = foo
    label.setText("Label")
    Frame.show()
    sys.exit(app.exec_())

label.mousePressEvent = lambda _: None - yyzhang14922

0
在PyQT5中,您可以尝试在setupUi中添加代码并创建clicked方法:
def setupUi()
   ... 
   self.label1.linkActivated.connect(self.clicked)
   ...

def clicked(self):
    print(self.label1.text()) #For example, printing the label text...

希望这能帮到你!


当 UI 被加载时,linkActivated 就会被调用,甚至不需要点击标签。 - V Surya Kumar

0
class ClickableLabel(QtWidgets.QLabel):
    def __init__(self, whenClicked, parent=None):
        QtWidgets.QLabel.__init__(self, parent)
        self._whenClicked = whenClicked

    def mouseReleaseEvent(self, event):
        self._whenClicked(event)

然后:

        my_label = ClickableLabel(self.my_label_clicked)
...
    def my_label_clicked(self, event):
        button = event.button()
        modifiers = event.modifiers()

        if modifiers == Qt.NoModifier and button == Qt.LeftButton:
            logger.debug('my_label_clicked: hooray!')
            return

        LOGGER.debug('my_label_clicked: unhandled %r', event)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接