有时需要在QDialog里禁止用户关闭窗口,Qdialog类关闭窗口的几个方式为:
- 按下esc键
- 点击右上角的关闭按钮(按alt+f4键)
- 执行窗口类中的close()方法
在第二种和第三种方式中,执行关闭的操作会触发Qdialog这个类本身自带的closeEvent()事件,因此只需要在类里面重新定义closeEvent即可。
def closeEvent(self, a0):
# a0.accept() # 允许关闭窗口
a0.ignore() # 拒绝关闭窗口
# 变量a0是一个QEvent类,有accept和ignore方法来确认是否确认关闭
但是以上方法无法防止第一种情况的关闭操作(即使重定向了关闭事件,按ESC键窗口还是会关闭)。此时可以重定向keyPressEvent函数(在键盘按下按键时会触发):
def keyPressEvent(self, a0):
# a0是Qkeyevent类(继承于Qevent)
if a0==Qt.Key_Escape:
# 当按下的是ESC键时,不允许执行所对应的操作
a0.ignore()
else:
# 否则允许执行对应的操作
a0.accept()
另外,还可以使用setWindowFlags函数来禁用关闭按钮(视觉效果更明显):
self.setWindowFlags(self.windowFlags() & ~Qt.WindowContextHelpButtonHint) # 去掉窗口上的问号
self.setWindowFlags(self.windowFlags() & ~Qt.WindowCloseButtonHint) # 禁用关闭按钮
使用以上的方法,可以防止用户关闭窗口。该方法适用于所有从qdialog继承的类(例如Qwizard)。
附总结示例代码:
from PyQt5.QtWidgets import QApplication, QDialog
from PyQt5.QtCore import Qt
from sys import argv, exit
class mydialog(QDialog):
def __init__(self):
super().__init__()
self.setWindowFlags(self.windowFlags() & ~Qt.WindowContextHelpButtonHint) # 去掉问号
self.setWindowFlags(self.windowFlags() & ~Qt.WindowCloseButtonHint) # 禁用关闭按钮
self.setWindowTitle('关不掉的窗口')
def closeEvent(self, a0):
a0.ignore() # 拒绝关闭窗口
# 变量a0是一个QEvent类,有accept和ignore方法来确认是否确认关闭
def keyPressEvent(self, a0):
# a0是Qkeyevent类(继承于Qevent)
if a0==Qt.Key_Escape:
# 当按下的是ESC键时,不允许执行所对应的操作
a0.ignore()
else:
# 否则允许执行对应的操作
a0.accept()
app = QApplication(argv)
dia = mydialog()
dia.show()
exit(app.exec_())
运行效果: