Обновлять вложенный QStackWidget при изменении индекса QListWidget
Я сталкиваюсь с проблемой, которую не могу решить, даже если это не должно быть трудным.
у меня есть QListWidget
с 5 пунктов (так 5 строк) и 2 связанных QStackedWidgets
, Первая состоит из 3 страниц: первая страница содержит еще одну вложенную QStackedWidgets
с 2 страницами. Итого всего 5 страниц.
Небольшой подарок, чтобы иметь представление:
Теперь я пытаюсь создать функцию, которая связывает QListWidget
и 2 QStackedWidget
, Я хотел бы, чтобы пункты 1 и 2 QListWidget
были связаны только с первой страницей родителя QStackedWidget
и первая и вторая страница вложенного QStackedWidget
в то время как пункты 3, 4 и 5 были связаны только с родителем QStackedWidget
(2-я, 3-я и 4-я страница).
Часть кода, которую я написал, выглядит следующим образом:
# connect the listWidget currentRow signal to a custom function
self.listWidget.currentRowChanged.connect(self.updateStacked)
def updateStacked(self):
idx = self.listWidget.currentRow()
if idx is 0 or idx is 1:
self.stackedPlotWidget.setCurrentIndex(0)
self.stackedNestedWidget.setCurrentIndex(1)
else:
self.stackedPlotWidget.setCurrentIndex(idx - 1)
но что-то не работает правильно: для QlistWidget
строки 0 и 1 работают хорошо, но, похоже, не принимая во внимание оператор else.
Некоторые предложения?
1 ответ
Правильный способ написать слот выглядит так:
self.listWidget.currentRowChanged.connect(self.updateStacked)
def updateStacked(self, row):
if 0 <= row <= 1:
self.stackedPlotWidget.setCurrentIndex(0)
self.stackedNestedWidget.setCurrentIndex(row)
elif row > 1:
self.stackedPlotWidget.setCurrentIndex(row - 1)
ОБНОВЛЕНИЕ:
Ниже приведен полный пример, показывающий, как обрабатывать все сигналы. Обратите внимание, что спин-бокс предназначен только для имитации установки индексов стековых виджетов программным способом.
import sys
from PyQt4 import QtCore, QtGui
class Window(QtGui.QWidget):
def __init__(self):
super(Window, self).__init__()
self.stack1 = QtGui.QStackedWidget()
self.stack2 = QtGui.QStackedWidget()
for text in 'ONE', 'TWO':
page = QtGui.QWidget(self.stack2)
layout = QtGui.QVBoxLayout(page)
layout.addWidget(QtGui.QLabel(text))
self.stack2.addWidget(page)
page = QtGui.QWidget(self.stack1)
layout = QtGui.QVBoxLayout(page)
layout.addWidget(QtGui.QLabel('TOP'))
layout.addWidget(self.stack2)
layout.addWidget(QtGui.QLabel('BOTTOM'))
self.stack1.addWidget(page)
for text in 'THREE', 'FOUR', 'FIVE':
page = QtGui.QWidget(self.stack1)
layout = QtGui.QVBoxLayout(page)
layout.addWidget(QtGui.QLabel(text))
self.stack1.addWidget(page)
self.listWidget = QtGui.QListWidget()
self.listWidget.addItems('ONE TWO THREE FOUR FIVE'.split())
self.listWidget.currentRowChanged.connect(self.updateStacked)
self.spin = QtGui.QSpinBox()
self.spin.setRange(0, 4)
self.spin.valueChanged.connect(self.updateStacked)
layout = QtGui.QHBoxLayout(self)
layout.addWidget(self.listWidget)
layout.addWidget(self.stack1)
layout.addWidget(self.spin)
self.stack1.currentChanged.connect(self.updateList)
self.stack2.currentChanged.connect(self.updateList)
def updateStacked(self, row):
if 0 <= row <= 1:
self.stack1.setCurrentIndex(0)
self.stack2.setCurrentIndex(row)
elif row > 1:
self.stack1.setCurrentIndex(row - 1)
def updateList(self, index):
self.listWidget.blockSignals(True)
if self.sender() is self.stack1:
index += (1 if index >= 1 else self.stack2.currentIndex())
self.listWidget.setCurrentRow(index)
self.listWidget.blockSignals(False)
if __name__ == '__main__':
app = QtGui.QApplication(sys.argv)
window = Window()
window.setGeometry(600, 50, 300, 50)
window.show()
sys.exit(app.exec_())