Как поместить GroupBox в GridLayout? PyQt4
Я хочу поместить групповой блок, который содержит много виджетов с флажками и кнопками, в GridLayout в PyQt4. Кроме того, я хочу иметь кнопку за пределами groupBox (но в том же макете), которая может запускать некоторые функции, щелкнув ее после того, как флажок (и) в отмечен.
Кроме того, я хотел бы иметь полосу прокрутки (возможно, QScrollArea?) Для группового поля, потому что я могу добавить больше кнопок в будущем.
Следует отметить, что в этом макете / окне есть несколько вкладок (я не уверен, что термин). И все групповое поле / кнопка / и т. Д. Должны все в Таблице 1.
Я прочитал несколько статей, в которых есть такие же ситуации, но ни одна из них не дает правильного ответа... Если кто-нибудь знает, как решить проблему, пожалуйста, дайте мне знать. Оценил!
РЕДАКТИРОВАТЬ: мои коды, как показано ниже. Как видите, у меня внизу есть групповая коробка. Что я хочу сделать, так это поместить групповой блок сверху со всеми флажками / кнопками, кроме кнопки "Выполнить" внизу за пределами группового блока. И все это должно произойти только в Таблице 1.
import PyQt4
from PyQt4 import QtGui, QtCore
from PyQt4.QtCore import *
from PyQt4.QtGui import *
import os, sys
class Page1 (QTabWidget):
def __init__(self, parent=None):
super(Page1, self).__init__(parent)
self.tab1 = QWidget()
self.tab2 = QWidget()
self.tab3 = QWidget()
self.addTab(self.tab1, "Tab1")
self.addTab(self.tab2, "Tab2")
self.addTab(self.tab3, "Tab3")
self.tab1_initUI()
self.tab2_initUI()
self.tab3_initUI()
def tab1_initUI(self):
btn1a = QPushButton('A1')
btn1a.resize(btn1a.sizeHint())
btn1b = QPushButton('A2')
btn1b.resize(btn1b.sizeHint())
btn2a = QPushButton('B1')
btn2a.resize(btn2a.sizeHint())
btn2b = QPushButton('B2')
btn2b.resize(btn2b.sizeHint())
btn3a = QPushButton('C1')
btn3a.resize(btn3a.sizeHint())
btn3b = QPushButton('C2')
btn3b.resize(btn3b.sizeHint())
btn4a = QPushButton('D1', self)
btn4a.resize(btn4a.sizeHint())
btn4b =QPushButton('D2', self)
btn4b.resize(btn4b.sizeHint())
btn5a = QPushButton('E1', self)
btn5a.resize(btn5a.sizeHint())
btn5b = QPushButton('E2', self)
btn5b.resize(btn5b.sizeHint())
self.checkBox1 = QtGui.QCheckBox('1', self)
self.checkBox2 = QtGui.QCheckBox('2', self)
self.checkBox3 = QtGui.QCheckBox('3', self)
self.checkBox4 = QtGui.QCheckBox('4', self)
self.checkBox5 = QtGui.QCheckBox('5', self)
btnRun = QPushButton('Run', self)
btnRun.resize(btnRun.sizeHint())
grid = QtGui.QGridLayout()
grid.addWidget(self.checkBox1, 1, 0)
grid.addWidget(btn1a, 1, 1)
grid.addWidget(btn1b, 1, 2)
grid.addWidget(self.checkBox2, 2, 0)
grid.addWidget(btn2a, 2, 1)
grid.addWidget(btn2b, 2, 2)
grid.addWidget(self.checkBox3, 3, 0)
grid.addWidget(btn3a, 3, 1)
grid.addWidget(btn3b, 3, 2)
grid.addWidget(self.checkBox4, 4, 0)
grid.addWidget(btn4a, 4, 1)
grid.addWidget(btn4b, 4, 2)
grid.addWidget(self.checkBox5, 5, 0)
grid.addWidget(btn5a, 5, 1)
grid.addWidget(btn5b, 5, 2)
grid.addWidget(btnRun, 6, 0, 1, 3)
groupbox = QtGui.QGroupBox(self)
hbox = QtGui.QHBoxLayout()
grid2= QtGui.QGridLayout()
hbox.addLayout(grid2)
groupbox.setLayout(hbox)
scroll = QtGui.QScrollArea()
scroll.setWidget(groupbox)
scroll.setWidgetResizable(True)
grid.addWidget(groupbox,7,0,1,3)
self.tab1.setLayout(grid)
def tab2_initUI(self):
grid = QtGui.QGridLayout()
self.tab2.setLayout(grid)
def tab3_initUI(self):
grid = QtGui.QGridLayout()
self.tab3.setLayout(grid)
class MainWindow(QMainWindow):
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.setGeometry(300, 200, 600, 370)
self.startPage1()
def startPage1(self):
x = Page1(self)
self.setWindowTitle("Auto Benchmark")
self.setCentralWidget(x)
self.show()
def main():
app = QApplication(sys.argv)
main = MainWindow()
main.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
1 ответ
Всегда целесообразно разделить задачи, в этом случае мы создадим класс Widget
где мы разместим кнопки и флажок.
class Widget(QWidget):
def __init__(self, parent=None):
QWidget.__init__(self, parent)
self.setLayout(QGridLayout())
for i in range(20):
letter = chr(ord('a') + i)
checkBox = QtGui.QCheckBox('{}'.format(i+1), self)
self.layout().addWidget(checkBox, i, 0)
btna = QPushButton("{}1".format(letter), self)
btnb = QPushButton("{}2".format(letter), self)
self.layout().addWidget(btna, i, 1)
self.layout().addWidget(btnb, i, 2)
Второй класс Tab1
который реализует виджет, который содержит Widget
с QScrollArea
и кнопка запуска:
class Tab1(QWidget):
def __init__(self, parent=None):
QWidget.__init__(self, parent)
self.setLayout(QGridLayout())
self.group = Widget(self)
scroll = QtGui.QScrollArea(self)
scroll.setWidget(self.group)
scroll.setWidgetResizable(True)
self.layout().addWidget(scroll)
self.runBtn = QPushButton("Run", self)
self.layout().addWidget(self.runBtn)
Затем добавьте кнопку в QTabWidget
(вам больше не нужна функция tab1_initUI()
)
class Page1(QTabWidget):
def __init__(self, parent=None):
super(Page1, self).__init__(parent)
self.tab1 = Tab1()
self.tab2 = QWidget()
self.tab3 = QWidget()
self.addTab(self.tab1, "Tab1")
self.addTab(self.tab2, "Tab2")
[...]
Скриншот:
Полный код находится по следующей ссылке