PyQt 多文档界面
一个典型的GUI应用程序可能有多个窗口。选项卡和堆叠的小部件允许一次激活一个这样的窗口。然而,很多时候这种方法可能不是很有用,因为其他窗口的视图被隐藏了。
同时显示多个窗口的一种方法是将它们创建为独立的窗口。这被称为SDI(单文档界面)。这需要更多的内存资源,因为每个窗口可能有自己的菜单系统、工具栏等。
多文档界面(MDI)应用程序消耗较少的内存资源。子窗口在主容器内相互排列。容器小部件称为 QMdiArea 。
QMdiArea小部件通常占据QMdiSubWindow类的中央小部件。该区域的子窗口是QMdiSubWindow类的实例。可以将任何QWidget设置为subWindow对象的内部小部件。MDI区域中的子窗口可以以级联或平铺的方式排列。
下表列出了QMdiArea类和QMdiSubWindow类的重要方法:
序号 | 方法与描述 |
---|---|
1 | addSubWindow() 将小部件添加为MDI区域的新子窗口 |
2 | removeSubWindow() 移除作为子窗口的内部小部件 |
3 | setActiveSubWindow() 激活子窗口 |
4 | cascadeSubWindows() 以级联方式排列MDI区域中的子窗口 |
5 | tileSubWindows() 以平铺方式排列MDI区域中的子窗口 |
6 | closeActiveSubWindow() 关闭当前活动的子窗口 |
7 | subWindowList() 返回MDI区域中子窗口的列表 |
8 | setWidget() 将QWidget设置为QMdiSubwindow实例的内部小部件 |
QMdiArea对象发出subWindowActivated()信号,而windowStateChanged()信号是由QMdisubWindow对象发出的。
示例
在以下示例中,QMainWindow包含一个菜单和一个MdiArea。
self.mdi = QMdiArea()
self.setCentralWidget(self.mdi)
bar = self.menuBar()
file = bar.addMenu("File")
file.addAction("New")
file.addAction("cascade")
file.addAction("Tiled")
菜单的Triggered()信号被连接到windowaction()函数。
file.triggered[QAction].connect(self.windowaction)
菜单的新操作在MDI区域添加一个标题为逐个增加的编号的子窗口。
MainWindow.count = MainWindow.count+1
sub = QMdiSubWindow()
sub.setWidget(QTextEdit())
sub.setWindowTitle("subwindow"+str(MainWindow.count))
self.mdi.addSubWindow(sub)
sub.show()
将当前显示的子窗口以级联和平铺方式安排在菜单的级联和平铺按钮上。
完整的代码如下所示 –
import sys
from PyQt4.QtCore import *
from PyQt4.QtGui import *
class MainWindow(QMainWindow):
count = 0
def __init__(self, parent = None):
super(MainWindow, self).__init__(parent)
self.mdi = QMdiArea()
self.setCentralWidget(self.mdi)
bar = self.menuBar()
file = bar.addMenu("File")
file.addAction("New")
file.addAction("cascade")
file.addAction("Tiled")
file.triggered[QAction].connect(self.windowaction)
self.setWindowTitle("MDI demo")
def windowaction(self, q):
print "triggered"
if q.text() == "New":
MainWindow.count = MainWindow.count+1
sub = QMdiSubWindow()
sub.setWidget(QTextEdit())
sub.setWindowTitle("subwindow"+str(MainWindow.count))
self.mdi.addSubWindow(sub)
sub.show()
if q.text() == "cascade":
self.mdi.cascadeSubWindows()
if q.text() == "Tiled":
self.mdi.tileSubWindows()
def main():
app = QApplication(sys.argv)
ex = MainWindow()
ex.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
上述代码产生以下输出−