QCloseEvent 类包含描述关闭事件的参数。
Header: | #include <QCloseEvent> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS Gui) target_link_libraries(mytarget PRIVATE Qt6::Gui) |
qmake: | QT += gui |
Inherits: | QEvent |
- 所有成员的列表,包括继承的成员
- QCloseEvent 是 Event 类的一部分。
【公有函数】
QCloseEvent::QCloseEvent()
构造关闭事件对象。
【详细描述】
关闭事件将发送到用户想要关闭的控件,通常是通过从窗口菜单中选择“关闭”或单击标题栏X按钮,也可以通过调用QWidget::close() 以代码方式发送这个事件。
关闭事件包含一个标志,标示接收方是否希望关闭控件,当控件接受accept关闭事件时,它将被隐藏(如果它标志为Qt::WA_DeleteOnClose 则会被销毁)。如果它拒绝接受关闭事件,则不会发生任何事情。
事件处理程序QWidget::closeEvent()接收关闭事件,默认会接受关闭事件。如果你不希望你的控件关闭,或者想要进行想要的特殊处理,可以重新实现closeEvent() 事件处理程序。
如果您希望在关闭控件时将其删除,请使用Qt::WA_DeleteOnClose ,这样当控件接受关闭事件的同时,也会让Qt删除该控件。这对于多窗口应用程序中的独立顶级窗口非常有用。
QObject在删除它们时发出 destroyed() 信号,该信号发出后,该对象的子对象都会立即被销毁。
如果最后一个顶级窗口关闭,则发出QGuiApplication::lastWindowClosed() 信号,QGUI程序在发出这个信号后就退出了。
isAccepted() 用以返回当前控件的受受状态,默认为真,表示事件的接收者同意关闭控件。可通过setAccepted(false)来拒绝被关闭。
参阅 QWidget::close(), QWidget::hide(), QObject::destroyed(), QCoreApplication::exec(), QCoreApplication::quit(), QGuiApplication::lastWindowClosed()