QDialog::open()
考虑到前文所述的问题,我们对比一下应用程序级别模态的实现。当windowModality是Qt::NonModal的时候,只需调用QDialog::exec()就可以很容易实现。那么,为什么不提供一个类似的函数,只需简单的调用一下就可以实现一个窗口级别的模态对话框呢?答案就是QDialog::open()。QDialog::open()可以打开一个窗口级别模态对话框。在 Mac OS X 上就是一个 sheet。为了正确实现事件循环,当函数调用之后会立即返回。这意味着你必须通过信号槽机制来实现对返回结果的处理。好在QDialog提供了finished()信号,该信号会正确设置对话框的返回值,类似accept()和reject()。当然,你也可以直接继承QDialog从而使用自己的 signal。那么,对于前面所说的QMessageBox的问题,我们只需使用QMessageBox::open()而不是show(),就可以简单的实现窗口级别模态对话框。即便是在 Mac OS X 平台上,我们也不需要指定Qt::Sheet参数。open()函数是跨平台的,这意味着它能够在所有平台上都以我们所期望的方式运行。现在,我们有了一个更加完善的映射关系:
QDialog::show()=>Qt::NonModal
QDialog::exec()=>Qt::ApplicationModal
QDialog::open()=>Qt::WindowModal
这么一来,选择模态类型比以前简单很多了。下面我们将讲解另外一个令人困惑的问题。
子类的 static 函数
提供新的open()函数的另外一个目的是,避免对 sheet 的误用。这意味着你无需手动设置Qt::Sheet参