QStackedWidget
===
類似`QTabWidget`,有別於`QTabWidget`是系統提供的,`QStackedWidget`則必須實作分頁的UI,以下範例用`QListWidget()`來達到選擇分頁的效果與畫面。
1. 建立**Left side** layot:使用`self.leftlist = QListWidget()`
2. 建立**Right side** layout:使用`self.Stack = QStackedWidget(self)`
3. **Left** **side** + **Right side** layout:使用`hbox = QHBoxLayout(self)`
4. Bind Left side to triger Right side:`self.leftlist.currentRowChanged.connect(self.display)`
5. 顯示對應的page\(Right side\):`self.Stack.setCurrentIndex(i)`
```python
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class stackedExample(QWidget):
def __init__(self):
super(stackedExample, self).__init__()
# LEFT SIDE
self.leftlist = QListWidget()
self.leftlist.insertItem(0, 'Contact')
self.leftlist.insertItem(1, 'Personal')
self.leftlist.insertItem(2, 'Educational')
# RIGHT SIDE
self.stack1 = QWidget()
self.stack2 = QWidget()
self.stack3 = QWidget()
self.stack1UI()
self.stack2UI()
self.stack3UI()
self.Stack = QStackedWidget(self)
self.Stack.addWidget(self.stack1)
self.Stack.addWidget(self.stack2)
self.Stack.addWidget(self.stack3)
# COMBINE LEFT SIDE + RIGHT SIDE
hbox = QHBoxLayout(self)
hbox.addWidget(self.leftlist)
hbox.addWidget(self.Stack)
self.setLayout(hbox)
# 綁定 LEFT SIDE 觸發 RIGHT SIDE
self.leftlist.currentRowChanged.connect(self.display)
self.setGeometry(300, 50, 10, 10)
self.setWindowTitle('StackedWidget demo')
self.show()
def stack1UI(self):
layout = QFormLayout()
layout.addRow("Name", QLineEdit())
layout.addRow("Address", QLineEdit())
# self.setTabText(0,"Contact Details")
self.stack1.setLayout(layout)
def stack2UI(self):
layout = QFormLayout()
sex = QHBoxLayout()
sex.addWidget(QRadioButton("Male"))
sex.addWidget(QRadioButton("Female"))
layout.addRow(QLabel("Sex"), sex)
layout.addRow("Date of Birth", QLineEdit())
self.stack2.setLayout(layout)
def stack3UI(self):
layout = QHBoxLayout()
layout.addWidget(QLabel("subjects"))
layout.addWidget(QCheckBox("Physics"))
layout.addWidget(QCheckBox("Maths"))
self.stack3.setLayout(layout)
def display(self, i):
self.Stack.setCurrentIndex(i)
def main():
app = QApplication(sys.argv)
ex = stackedExample()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
```
## Ref.
[https://www.tutorialspoint.com/pyqt5/pyqt5\_qstackedwidget.htm](https://www.tutorialspoint.com/pyqt5/pyqt5\_qstackedwidget.htm)
###### tags: `PyQt5`