3

画面上部に 4 つのボタンがあるインターフェイスがあり、その下に QFrame があります。押されたボタンに基づいて QFrame のレイアウトを変更したい。たとえば、Button_1 が押された場合は TextEdit ウィジェットを表示し、Button_2 が押された場合は ListViewWidget を表示します。

これをどのように行うことができるかについて誰にも考えがありますか? どうもありがとうございます!

4

2 に答える 2

6

a を使用しQStackedLayoutてウィジェットを保存します。その後、 の付いたものに変更できますsetCurrentIndex。または、 の代わりに を使用できQStackedWidgetますQFrame

簡単な例:

import sys
from PySide import QtGui

class Window(QtGui.QWidget):
    def __init__(self, parent=None):
        super(Window, self).__init__(parent)

        self.textEdit = QtGui.QTextEdit('Text Edit')
        self.listWidget = QtGui.QListWidget()
        self.listWidget.addItem('List Widget')
        self.label = QtGui.QLabel('Label')

        self.stackedLayout = QtGui.QStackedLayout()
        self.stackedLayout.addWidget(self.textEdit)
        self.stackedLayout.addWidget(self.listWidget)
        self.stackedLayout.addWidget(self.label)

        self.frame = QtGui.QFrame()
        self.frame.setLayout(self.stackedLayout)

        self.button1 = QtGui.QPushButton('Text Edit')
        self.button1.clicked.connect(lambda: self.stackedLayout.setCurrentIndex(0))
        self.button2 = QtGui.QPushButton('List Widget')
        self.button2.clicked.connect(lambda: self.stackedLayout.setCurrentIndex(1))
        self.button3 = QtGui.QPushButton('Label')
        self.button3.clicked.connect(lambda: self.stackedLayout.setCurrentIndex(2))

        buttonLayout = QtGui.QHBoxLayout()
        buttonLayout.addWidget(self.button1)
        buttonLayout.addWidget(self.button2)
        buttonLayout.addWidget(self.button3)

        layout = QtGui.QVBoxLayout(self)
        layout.addLayout(buttonLayout)
        layout.addWidget(self.frame)


if __name__ == '__main__':
    app = QtGui.QApplication(sys.argv)

    w = Window()
    w.show()

    sys.exit(app.exec_())
于 2013-01-11T08:55:24.163 に答える
2

何かのようなもの...

myframe.layout().removeWidget(mywidget)
mywidget = QTextEdit()
myframe.layout().addWidget(myWidget)
于 2013-01-10T22:32:49.887 に答える