2014-09-03 58 views
0

我想要生成一个GridLayout(CheckBox的)和HLayout堆叠布局的对话框。那么,我做到了。但我的网格变大了(我的HLayout很好),但现在我想要一个ScrollArea,以免占用太多的房地产。我尝试了下面的代码....它会生成一个滚动视图,但滚动视图的大小是HLayout中按钮的大小(第一个ofc)。我希望滚动视图是对话框的宽度,名义上它应该是HLayout的最小宽度。此外,添加scroll_view和scroll_viewWidget会引发QLayout异常,QLayout :: addChildLayout:layout“”已经有父级。有任何想法吗?Python PyQt QScrollArea和QGridLayout(或任何?)

class checkboxDialog(QtGui.QDialog) : 

def __init__(self, headers, name) : 
    super(checkboxDialog, self).__init__() 

    self.checkerLayout = QtGui.QVBoxLayout() 
    self.checkerLayout.setMargin(1) 
    self.checkerLayout.setSpacing(2) 

    self.scroll_view = QtGui.QScrollArea(self) 
    self.scroll_view.setWidgetResizable(True) 

    self.scroll_viewWidget = QtGui.QWidget() 
    self.scroll_viewWidget.setGeometry(QtCore.QRect(0, 0, 600, 400)) 
    self.scroll_view.setWidget(self.scroll_viewWidget)   

    self.checkerHlayout = QtGui.QHBoxLayout(self.scroll_viewWidget) 

    checksLayout = QtGui.QGridLayout() 
    checksLayout.setColumnStretch(90,7) 
    checksLayout.setMargin(1) 
    checksLayout.setSpacing(2)  
    self.cbList = [] 
    index = 0 
    for row_index in range(90): 
     for column_index in range(7): 
      if index > len(headers)-1 : break 
      checkbox = QtGui.QCheckBox(headers[index][0:8], self) 
      checkbox.setToolTip("Chanel = {}".format(headers[index])) 
      self.cbList.append(checkbox) 
      # Hide the Phase channels for now ... not sure I shoudl even build the CheckBoxes 
      # But if I dont then the len(cbList) < len(data[0]) 
      if headers[index][-1] == 'p' : 
       checkbox.hide() 
      checksLayout.addWidget(checkbox, row_index, column_index) 
      index += 1 

    self.checkerHlayout.addLayout(checksLayout) 

    self.buttonLayout = QtGui.QHBoxLayout() 
    self.buttonLayout.setMargin(1) 
    self.buttonLayout.setSpacing(2) 

    applyButton = QtGui.QPushButton("Apply") 
    nextButton = QtGui.QPushButton("Next") 
    nextAllButton = QtGui.QPushButton("NextAll") 
    prevButton = QtGui.QPushButton("Prev") 
    prevAllButton = QtGui.QPushButton("PrevAll") 
    clearButton = QtGui.QPushButton("Clear") 

    self.buttonLayout.addWidget(applyButton)   
    self.buttonLayout.addWidget(nextButton) 
    self.buttonLayout.addWidget(nextAllButton) 
    self.buttonLayout.addWidget(prevButton) 
    self.buttonLayout.addWidget(prevAllButton) 
    self.buttonLayout.addWidget(clearButton) 

    self.checkerLayout.addLayout(self.checkerHlayout) 
    self.checkerLayout.addLayout(self.buttonLayout) 
    self.setLayout(self.checkerLayout) 

    self.setObjectName(name) 
    self.setWindowTitle(name) 

    self.connect(applyButton, QtCore.SIGNAL('clicked()'), self.checked) 
    self.connect(nextButton, QtCore.SIGNAL('clicked()'), self.next_chn) 
    self.connect(nextAllButton, QtCore.SIGNAL('clicked()'), self.next_chnAll) 
    self.connect(prevButton, QtCore.SIGNAL('clicked()'), self.prev_chn) 
    self.connect(prevAllButton, QtCore.SIGNAL('clicked()'), self.prev_chnAll) 
    self.connect(clearButton, QtCore.SIGNAL('clicked()'), self.clear_chn) 

回答

1

我想这是你想要的东西:

self.w2 = QtGui.QWidget(self) 
    self.w2.setLayout(self.buttonLayout) 
    self.checkerLayout.addWidget(self.w2) 
    self.checkerLayout.addWidget(self.scroll_view) 
    self.setLayout(self.checkerLayout) 

(替换用addLayout语句块)

+0

没错!那是做的......你说我不明白为什么,我很抱歉。 – 2014-09-03 22:29:19

+0

@TimCarnahan你在'checkerLayout'上两次调用'addLayout'。 mdurant嵌套可能是你想要的布局。 – Trilarion 2014-09-04 08:55:56

+0

顺便说一句,我建议使用QtDesigner来制作复杂的GUI,即使在运行时需要动态填充某些元素,也会带来很多痛苦。 – mdurant 2014-09-04 12:32:37