Python中PyQt4的对齐按钮
这是我第一次使用PyQt4开发应用程序。
我遇到了以下两个问题:
左边框中的按钮,它们的间距不一样。
可以让单选按钮使用斜体吗?(比如说,Ke et al. 而不是 Ke et al.)?
import sys
from PyQt4 import QtGui, QtCore
class MainWindow(QtGui.QMainWindow):
def __init__(self):
QtGui.QMainWindow.__init__(self)
# title of the window
self.setWindowTitle('Segmentation Accuracy')
# fix window size
self.setFixedSize(400,200)
# status bar with initial message
self.statusBar().showMessage('ready')
# Layout
# contiene gli altri widget
cWidget = QtGui.QWidget(self)
grid = QtGui.QGridLayout(cWidget)
# Box Left
vBox_left = QtGui.QVBoxLayout()
vBox_left.setSpacing(2) #set spacing
Button_input1 = QtGui.QPushButton("Reference Polygons")
vBox_left.addWidget(Button_input1)
Button_input2 = QtGui.QPushButton("Segmented Polygons")
vBox_left.addWidget(Button_input2)
Button_output = QtGui.QPushButton("Save")
vBox_left.addWidget(Button_output)
Button_start = QtGui.QPushButton("Start")
Button_start.setCheckable(True)
vBox_left.addWidget(Button_input1)
vBox_left.addWidget(Button_input2)
vBox_left.addWidget(Button_output)
vBox_left.addWidget(Button_start)
# Box right
vBox_rigth = QtGui.QVBoxLayout()
vBox_rigth.setSpacing(10) #set spacing
ke = QtGui.QRadioButton("Ke et al.", cWidget)
pu = QtGui.QRadioButton("Pu et al.", cWidget)
clinton = QtGui.QRadioButton("Clinton et al.", cWidget)
ke.setChecked(True)
vBox_rigth.addWidget(ke)
vBox_rigth.addWidget(pu)
vBox_rigth.addWidget(clinton)
ke.setStatusTip("Ke et al., 2010. Remote Sensing of Environment, 114, pp. 1141-1154")
pu.setStatusTip("Pu et al., 2012. Remote Sensing of Environment, 124, pp. 516-533")
clinton.setStatusTip("Clinton et al., 2012. Remote Sensing of Environment, 124, pp. 516-533")
grid.addWidget(Button_input1, 0, 0)
grid.addWidget(Button_input2, 1, 0)
grid.addWidget(Button_output, 2, 0)
grid.addWidget(Button_start, 3, 0)
grid.addLayout(vBox_left, 0, 0)
grid.addLayout(vBox_rigth, 0, 1)
cWidget.setLayout(grid)
self.setCentralWidget(cWidget)
def main():
app = QtGui.QApplication(sys.argv)
main = MainWindow()
main.show()
sys.exit(app.exec_())
main()
1 个回答
2
你使用了 QGridLayout
,把 Button_input1
放在了第一个单元格 (0,0),而包含三个单选按钮的布局 vBox_rigth
放在了第二个单元格 (0,1)。它们的高度被调整成了一样的。这就是为什么你的四个按钮之间的间距不一样的原因。
grid = QtGui.QGridLayout(cWidget)
......
grid.addWidget(Button_input1, 0, 0)
......
grid.addLayout(vBox_rigth, 0, 1)
你不应该把那些按钮在 vBox_left
中添加两次。
Button_input1 = QtGui.QPushButton("Reference Polygons")
vBox_left.addWidget(Button_input1)
Button_input2 = QtGui.QPushButton("Segmented Polygons")
vBox_left.addWidget(Button_input2)
Button_output = QtGui.QPushButton("Save")
vBox_left.addWidget(Button_output)
Button_start = QtGui.QPushButton("Start")
Button_start.setCheckable(True)
vBox_left.addWidget(Button_input1)
vBox_left.addWidget(Button_input2)
vBox_left.addWidget(Button_output)
vBox_left.addWidget(Button_start)
而且,这四个按钮已经被添加到 vBox_left
的垂直布局中了,所以你不应该再把它们添加到 grid
中。
grid.addWidget(Button_input1, 0, 0)
grid.addWidget(Button_input2, 1, 0)
grid.addWidget(Button_output, 2, 0)
grid.addWidget(Button_start, 3, 0)
你可以使用斜体来显示小部件。你只需要改变 font
属性。可以参考这个链接:http://doc.qt.digia.com/stable/qwidget.html#font-prop。
例如:
ke = QtGui.QRadioButton("Ke et al.", cWidget)
font = QtGui.QFont("Times", 10)
font.setItalic(True)
ke.setFont(font)
你也可以使用 QLabel
来显示富文本。例如:
ke_label = QtGui.QLabel("Ke <i>et al</i>.")
因此,最终的 __init__
可能是这样的:
def __init__(self):
QtGui.QMainWindow.__init__(self)
# title of the window
self.setWindowTitle('Segmentation Accuracy')
# fix window size
self.setFixedSize(400,200)
# status bar with initial message
self.statusBar().showMessage('ready')
# Layout
# contiene gli altri widget
cWidget = QtGui.QWidget(self)
grid = QtGui.QGridLayout(cWidget)
# Box Left
vBox_left = QtGui.QVBoxLayout()
vBox_left.setSpacing(2) #set spacing
Button_input1 = QtGui.QPushButton("Reference Polygons")
vBox_left.addWidget(Button_input1)
Button_input2 = QtGui.QPushButton("Segmented Polygons")
vBox_left.addWidget(Button_input2)
Button_output = QtGui.QPushButton("Save")
vBox_left.addWidget(Button_output)
Button_start = QtGui.QPushButton("Start")
Button_start.setCheckable(True)
# vBox_left.addWidget(Button_input1)
# vBox_left.addWidget(Button_input2)
# vBox_left.addWidget(Button_output)
vBox_left.addWidget(Button_start)
# Box right
vBox_right = QtGui.QVBoxLayout()
vBox_right.setSpacing(10) #set spacing
ke = QtGui.QRadioButton("", cWidget)
pu = QtGui.QRadioButton("", cWidget)
clinton = QtGui.QRadioButton("", cWidget)
ke.setChecked(True)
ke_label = QtGui.QLabel("Ke <i>et al</i>.", cWidget)
pu_label = QtGui.QLabel("Pu et al.", cWidget)
clinton_label = QtGui.QLabel("Clinton et al.", cWidget)
grid_right = QtGui.QGridLayout()
grid_right.addWidget(ke, 0, 0)
grid_right.addWidget(pu, 1, 0)
grid_right.addWidget(clinton, 2, 0)
grid_right.addWidget(ke_label, 0, 1)
grid_right.addWidget(pu_label, 1, 1)
grid_right.addWidget(clinton_label, 2, 1)
grid.addLayout(grid_right, 0, 1)
grid.setColumnStretch(0, 1)
grid.setColumnStretch(1, 1)
grid_right.setColumnStretch(1, 1)
ke.setStatusTip("Ke et al., 2010. Remote Sensing of Environment, 114, pp. 1141-1154")
pu.setStatusTip("Pu et al., 2012. Remote Sensing of Environment, 124, pp. 516-533")
clinton.setStatusTip("Clinton et al., 2012. Remote Sensing of Environment, 124, pp. 516-533")
ke_label.setStatusTip("Ke et al., 2010. Remote Sensing of Environment, 114, pp. 1141-1154")
pu_label.setStatusTip("Pu et al., 2012. Remote Sensing of Environment, 124, pp. 516-533")
clinton_label.setStatusTip("Clinton et al., 2012. Remote Sensing of Environment, 124, pp. 516-533")
# grid.addWidget(Button_input1, 0, 0)
# grid.addWidget(Button_input2, 1, 0)
# grid.addWidget(Button_output, 2, 0)
# grid.addWidget(Button_start, 3, 0)
grid.addLayout(vBox_left, 0, 0)
#grid.addLayout(vBox_right, 0, 1)
# cWidget.setLayout(grid)
self.setCentralWidget(cWidget)