如何在 PyQt5 中更改 space 栏行为,Python3

How to change space bar behaviour in PyQt5, Python3

我使用 PyQt5 和 Python3 为工作制作了一个 ui。除了单击按钮外,我还想通过按键盘上的特定键来执行特定操作,例如space 栏。我使用了以下方法:

def keyPressEvent(self, event):
    key = event.key()

    if key == Qt.Key_Space:
        print('space')
    elif key == Qt.Key_W:
        print('w')

当我按下 space 栏时,它按下 ui 中的聚焦按钮,而不是打印 'space'。就像我打return一样。尽管按 'W' 键会按预期打印 'w'。

我已经在 Whosebug 和网络上的其他地方进行了搜索,但没有找到真正有用的东西。我得到的最好的是这个 here。但它使用 PyQt4.3 并将代码复制并粘贴到我的编辑器中,这给我带来了一些错误。我认为这种方法很好,但我无法将其转移到 PyQt5。

试一试:

#from PyQt4.QtCore import * 
#from PyQt4.QtGui import * 
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore    import *
from PyQt5.QtGui     import * 


class MyWindow(QWidget): 
    def __init__(self, *args): 
        QWidget.__init__(self, *args)

        # create objects
        self.la  = QLabel("Press Space or `w` in this box:")
        self.le  = MyLineEdit()
        self.la2 = QLabel("\nLook here:")
        self.le2 = QLineEdit()

        self.btnSpace = QPushButton("Button1")
        self.btnSpace.setEnabled(False)
        self.btnSpace.clicked.connect(self.onBtnSpace)
        self.btnW     = QPushButton("Button2")
        self.btnW.setEnabled(False)
        self.btnW.clicked.connect(self.onBtnW)


        # layout
        layout = QVBoxLayout()
        layout.addWidget(self.la)
        layout.addWidget(self.le)
        layout.addWidget(self.la2)
        layout.addWidget(self.le2)

        layout.addWidget(self.btnSpace)
        layout.addWidget(self.btnW)

        self.setLayout(layout)

        # connections
        #self.connect(self.le, SIGNAL("tabPressed"), self.update)
        self.le.signalTabPressed[str].connect(self.update)

    def update(self, keyPressed):
        newtext = str(self.le2.text()) + str(keyPressed)  #"tab pressed "
        self.le2.setText(newtext)

        if keyPressed == "Key Space; ":
            self.btnSpace.setEnabled(True)
            self.btnSpace.setText(str(keyPressed))

        if keyPressed == "Key W; ":
            self.btnW.setEnabled(True)
            self.btnW.setText(str(keyPressed))        


    def onBtnSpace(self):
        print("keyPressed -> btnSpace")

    def onBtnW(self):
        print("keyPressed -> btnW")       

class MyLineEdit(QLineEdit):
    signalTabPressed = pyqtSignal(str)                  # +++

    def __init__(self, *args):
        QLineEdit.__init__(self, *args)

    def event(self, event):
        #if (event.type()==QEvent.KeyPress) and (event.key()==Qt.Key_Tab):
        if (event.type()==QEvent.KeyPress) and (event.key()==Qt.Key_Space):
            self.signalTabPressed.emit("Key Space; ")
            return True
        if (event.type()==QEvent.KeyPress) and (event.key()==Qt.Key_W):
            self.signalTabPressed.emit("Key W; ")    
            return True

        return QLineEdit.event(self, event)



def main(): 
    app = QApplication(sys.argv) 
    w   = MyWindow() 
    w.show() 
    sys.exit(app.exec_()) 

if __name__ == "__main__": 
    main()

通过 S. Nick 非常有用的回答,我找到了一个真正符合我需求的解决方案。

class MyPushButton(QPushButton):
    def __init__(self, *args):
        QPushButton.__init__(self, *args)

    def event(self, event):
        if (event.type() == QEvent.KeyPress) and (event.key() == Qt.Key_Space):
            print(foo)

            return True

        return QPushButton.event(self, event)

所以,就是这样。每当我按下键盘上的 space 键时,它只会打印 foo 而没有其他内容。 print(foo) 显然只是我想做的任何事情的占位符。