PyQt 防止 QInputDialog 在 ESC/Enter 交叉点击时关闭
PyQt Prevent QInputDialog from closing on ESC/Enter cross click
我创建了 QInputDialog 并在其中配置了事件过滤器,但我不知道如何防止它在 eventFilter(self, widget, event)
方法中单击 ESC 或 ENTER 按钮时关闭。
self.inDialog = QInputDialog(self)
#some config...
self.inDialog.setLabelText('')
self.nameAction.setText('&Nazwa pola głównego ✔')
self.inDialog.show()
我的事件过滤器概念:
def eventFilter(self, widget, event):
if isinstance(event, QtGui.QKeyEvent):
if event.key() == 16777220:
return False
# here I want to call super somehow?
return
值得一提的是,我在 QMainWindow class 中执行所有这些操作,我从中调用此 QInputdialog。我宁愿不要 subclass QDialog 并手动编写所有内容。
如果你想避免事件发生在 QInputDialog
你必须 return True
在过滤器中,另一方面最好使用 Qt::Key
使代码更具可读性。
from PyQt5 import QtCore, QtGui, QtWidgets
class MainWindow(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
button = QtWidgets.QPushButton("Press me")
button.clicked.connect(self.opendialog)
self.setCentralWidget(button)
self.inDialog = QtWidgets.QInputDialog()
self.inDialog.setLabelText('')
self.inDialog.installEventFilter(self)
@QtCore.pyqtSlot()
def opendialog(self):
if self.inDialog.exec_() == QtWidgets.QDialog.Accepted:
print("Acepted")
print(self.inDialog.textValue())
def eventFilter(self, obj, event):
if obj is self.inDialog and event.type() == QtCore.QEvent.KeyPress:
if event.key() in (QtCore.Qt.Key_Return,
QtCore.Qt.Key_Escape,
QtCore.Qt.Key_Enter,):
return True
return super(MainWindow, self).eventFilter(obj, event)
if __name__ == '__main__':
import sys
app = QtWidgets.QApplication(sys.argv)
w = MainWindow()
w.show()
sys.exit(app.exec_())
更新: + 禁用关闭按钮:
def eventFilter(self, obj, event):
if obj is self.inDialog:
if event.type() == QtCore.QEvent.KeyPress:
if event.key() in (QtCore.Qt.Key_Return,
QtCore.Qt.Key_Escape,
QtCore.Qt.Key_Enter,):
return True
if event.type() == QtCore.QEvent.Close:
event.ignore()
return True
return super(MainWindow, self).eventFilter(obj, event)
我创建了 QInputDialog 并在其中配置了事件过滤器,但我不知道如何防止它在 eventFilter(self, widget, event)
方法中单击 ESC 或 ENTER 按钮时关闭。
self.inDialog = QInputDialog(self)
#some config...
self.inDialog.setLabelText('')
self.nameAction.setText('&Nazwa pola głównego ✔')
self.inDialog.show()
我的事件过滤器概念:
def eventFilter(self, widget, event):
if isinstance(event, QtGui.QKeyEvent):
if event.key() == 16777220:
return False
# here I want to call super somehow?
return
值得一提的是,我在 QMainWindow class 中执行所有这些操作,我从中调用此 QInputdialog。我宁愿不要 subclass QDialog 并手动编写所有内容。
如果你想避免事件发生在 QInputDialog
你必须 return True
在过滤器中,另一方面最好使用 Qt::Key
使代码更具可读性。
from PyQt5 import QtCore, QtGui, QtWidgets
class MainWindow(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
button = QtWidgets.QPushButton("Press me")
button.clicked.connect(self.opendialog)
self.setCentralWidget(button)
self.inDialog = QtWidgets.QInputDialog()
self.inDialog.setLabelText('')
self.inDialog.installEventFilter(self)
@QtCore.pyqtSlot()
def opendialog(self):
if self.inDialog.exec_() == QtWidgets.QDialog.Accepted:
print("Acepted")
print(self.inDialog.textValue())
def eventFilter(self, obj, event):
if obj is self.inDialog and event.type() == QtCore.QEvent.KeyPress:
if event.key() in (QtCore.Qt.Key_Return,
QtCore.Qt.Key_Escape,
QtCore.Qt.Key_Enter,):
return True
return super(MainWindow, self).eventFilter(obj, event)
if __name__ == '__main__':
import sys
app = QtWidgets.QApplication(sys.argv)
w = MainWindow()
w.show()
sys.exit(app.exec_())
更新: + 禁用关闭按钮:
def eventFilter(self, obj, event):
if obj is self.inDialog:
if event.type() == QtCore.QEvent.KeyPress:
if event.key() in (QtCore.Qt.Key_Return,
QtCore.Qt.Key_Escape,
QtCore.Qt.Key_Enter,):
return True
if event.type() == QtCore.QEvent.Close:
event.ignore()
return True
return super(MainWindow, self).eventFilter(obj, event)