概述
QMdiArea添加窗口有两种方式:
QMdiArea mdiArea;
//方式1
QMdiSubWindow *subWindow1 = new QMdiSubWindow;
subWindow1->setWidget(internalWidget1);
mdiArea.addSubWindow(subWindow1);
//方式2
QMdiSubWindow *subWindow2 = mdiArea.addSubWindow(internalWidget2);
当关闭方式1创建的子窗口时,子窗口不会被删除,只是被隐藏了,如果想关闭窗口时立即删除,可以添加这个语句:
subWindow1->setAttribute(Qt::WA_DeleteOnClose);
当关闭方式2创建的子窗口时,子窗口同时被删除,因为Qt帮我们设置了Qt::WA_DeleteOnClose属性。
//------------------------------------------------------分割线----------------------------------------------------
回到标题,关闭一个QMdiSubWindow时如何不删除这个窗口,我们可以使用方式1,但是这种做法只是隐藏了窗口,这个窗口其实还保留在QMdiArea,这并不符合用户对于"关闭"的认知。
我的做法是子类化QMdiSubWindow,重写closeEvent,当发生关闭事件时,使用QMdiArea::removeSubWindow移除子窗口,QMdiArea::removeSubWindow并不会删除子窗口。
代码如下:
.h
class MdiSubWindow : public QMdiSubWindow //mouze
{
Q_OBJECT
public:
explicit MdiSubWindow(QWidget *parent = 0);
signals:
void requestRemove(); //发给mdiArea,请求从mdiArea移除本窗口
protected:
void closeEvent(QCloseEvent *closeEvent);
};
.cpp
MdiSubWindow::MdiSubWindow(QWidget *parent) : QMdiSubWindow(parent)
{
}
void MdiSubWindow::closeEvent(QCloseEvent *closeEvent)
{
emit requestRemove();
closeEvent->accept();
}
//使用示例
{
MdiSubWindow *pWin = new MdiSubWindow;
pWin->setWidget(internalWidget); //internalWidget的类型是QWidget*
ui->mdiArea->addSubWindow(pWin);
pWin->show();
connect(pWin, &MdiSubWindow::requestRemove, []
{
QMdiSubWindow *w = qobject_cast<QMdiSubWindow *>(sender());
if (w == ui->mdiArea->activeSubWindow())
{
//如果要关闭的窗口是actived,先切换焦点
QList<QMdiSubWindow *> subwins =
ui->mdiArea>subWindowList(QMdiArea::ActivationHistoryOrder);
int index = subwins.size() - 1 - 1;
if (index >= 0)
{
ui->mdiArea->setActiveSubWindow(subwins.at(index));
}
else
{
ui->mdiArea->setActiveSubWindow(0);
}
}
ui->mdiArea->removeSubWindow(w);
w->hide();
});
}
最后
以上就是哭泣招牌为你收集整理的QMdiArea关闭窗口(QMdiSubWindow),如何不删除这个窗口的全部内容,希望文章能够帮你解决QMdiArea关闭窗口(QMdiSubWindow),如何不删除这个窗口所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复