1 回答

TA貢獻(xiàn)1943條經(jīng)驗(yàn) 獲得超7個(gè)贊
第二個(gè)示例不起作用,因?yàn)槟噲D重寫該event方法,該方法僅適用于 QWidget 子類,而您Ui_MainWindow是一個(gè)簡(jiǎn)單的 pythonobject子類,因此永遠(yuǎn)不會(huì)調(diào)用它。
該event()方法由 Qt 在任何 QWidget 上調(diào)用,并且由于您在第一個(gè)示例中重寫了它,因此實(shí)際上調(diào)用了您的方法。在第二個(gè)示例中,您沒有重寫 QWidget event,但您只是創(chuàng)建了一個(gè)永遠(yuǎn)不會(huì)被任何東西調(diào)用的函數(shù)。
理論上,您可以覆蓋對(duì)象event的方法(這就是所謂的“猴子修補(bǔ)”):MainWindowsetupUi
def setupUi(self, MainWindow):
# ...
MainWindow.event = self.event
但這是行不通的,因?yàn)閟elf您在該函數(shù)中引用的實(shí)際上是實(shí)例Ui_MainWindow,而不是實(shí)際的 QMainWindow 實(shí)例。雖然您可以使用 lambda,并使用 MainWindow 實(shí)例添加參數(shù),但我強(qiáng)烈建議您不要這樣做,下面的解釋將闡明為什么您不應(yīng)該這樣做。
出于簡(jiǎn)單的原因,做您想要實(shí)現(xiàn)的目標(biāo)是沒有意義的:修改或嘗試模仿“pyuic”生成的文件的行為是**永遠(yuǎn)**不應(yīng)該做的事情。
不鼓勵(lì)編輯主要是因?yàn)槊慨?dāng)您需要從設(shè)計(jì)器更改 UI 中的某些內(nèi)容時(shí),您最終都會(huì)嘗試將新生成的代碼(希望您同時(shí)沒有覆蓋該文件)與現(xiàn)有代碼集成,這將導(dǎo)致通常會(huì)導(dǎo)致大量錯(cuò)誤、問題、崩潰和頭痛。
不鼓勵(lì)編輯或模仿,因?yàn)檫@使得實(shí)現(xiàn)簡(jiǎn)單的類操作或覆蓋現(xiàn)有方法變得非常困難。另外,雖然我可以理解您有興趣研究它是如何工作的,但除了閱讀如何在 中創(chuàng)建界面之外setupUi,沒有什么可以學(xué)習(xí)的了。pyuic 文件僅用作“實(shí)用層”,以簡(jiǎn)化 PyQt 中的編程,它們應(yīng)始終僅按照有關(guān)使用 Designer 的官方指南中的建議進(jìn)行導(dǎo)入和使用。
如果您想實(shí)現(xiàn)第一個(gè)示例的事件,您需要使用您自己的子類并使用上面鏈接中建議的方法之一。最常見且易于使用的是多重繼承方法:
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QLineEdit, QFormLayout
from PyQt5.QtCore import Qt, QEvent
from ui_mainwindow import Ui_MainWindow
class Working(QMainWindow, Ui_MainWindow):
def __init__(self):
super().__init__()
self.setupUi(self)
def event(self, event):
if event.type() == QEvent.KeyPress:
if event.key() in (Qt.Key_Return, Qt.Key_Enter):
self.focusNextPrevChild(True)
return super().event(event)
if __name__ == "__main__":
import sys
app = QApplication(sys.argv)
mainWindow = Working()
mainWindow.show()
sys.exit(app.exec_())
注意:我假設(shè)您已使用再次生成pyuic了該文件,并且該文件名為ui_mainwindow.py; 另請(qǐng)注意,如果您在設(shè)計(jì)器中使用 QMainWindow,則必須從同一類(QMainWindow,而不是 QWidget)繼承子類;最后,由于您已經(jīng)從 QMainWindow和Ui_MainWindow 進(jìn)行子類化,因此您必須創(chuàng)建 的實(shí)例Working,而不是 QMainWindow 之一,也不是 Ui_MainWindow 之一。
另一種可能性是使用該uic模塊,它允許直接導(dǎo)入.ui文件,而無需每次都重建整個(gè)界面。
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QLineEdit, QFormLayout
from PyQt5.QtCore import Qt, QEvent
from PyQt5.uic import loadUi
class Working(QMainWindow, Ui_MainWindow):
def __init__(self):
super().__init__()
loadUi('mainWindow.ui', self)
# ...
添加回答
舉報(bào)