2

我有一个QGridLayout并且需要删除它的所有按钮然后重新创建它们。我尝试使用 after 循环遍历布局count()takeAt()删除返回LayoutItem的小部件。然而,出于某种原因,我只得到了一半的小部件:其他LayoutItem的没有小部件。正如我所看到的,这很奇怪。

这是我当前的简化代码。

import sys
from PySide.QtGui import *
from PySide.QtCore import *

class GridView(QWidget):

    def __init__(self, parent=None):
        super(GridView, self).__init__(parent)
        self.grid = QGridLayout(self)

    def setButtons(self):

        self.clearPage()
        for i in xrange(10):
            btn = QPushButton(str(i))
            self.grid.addWidget(btn, i / 2, i % 2)

    def clearPage(self):
        for i in xrange(self.grid.count()):
            print i
            layoutItem = self.grid.takeAt(i)
                # the following errors out after the fifth iteration as layoutItem.widget() returns None
            print layoutItem.widget()
            layoutItem.widget().deleteLater()


app = QApplication(sys.argv)
mainWindow = QWidget()
layout = QVBoxLayout()
mainWindow.setLayout(layout)
btn = QPushButton('test')
v = GridView()
btn.clicked.connect(v.setButtons)

layout.addWidget(v)
layout.addWidget(btn)
mainWindow.show()
sys.exit(app.exec_())
4

1 回答 1

3

尝试使用

self.grid.takeAt( 0 ) 

代替:

self.grid.takeAt(i)

在您的代码中,您在第一次迭代中采取At(0)。这在内部使旧的#1 成为新的#0,旧的#2 成为新的#1,依此类推。

然后在您的下一次迭代中,您采用At(1),这实际上是旧的#2。这样旧的#1(现在是#0)就不会被删除。

于 2012-07-13T08:03:57.340 回答