PyQt中弹出对话框操作

http://www.jimmykuu.me/blog/9

 

经常有初学者搞不清楚如何在PyQt中弹出对话框,以及如何处理返回值。这篇文章会举例说明,界面采用手工编写。

我们一般说的对话框指的是模态对话框(Modal Dialogue Box),一旦弹出,就不能对话框以外的窗口进行操作,必须先关闭对话框。

在PyQt中我们一般从QDialog继承创建一个类来操作,根据exec_()方法的返回值判断用户是【确定】还是【取消】了,当然也可以其他返回值,具体看文档。

这个例子创建一个主窗口,有一个表格,记录用户姓名和年龄,一个【添加】按钮,点击弹出对话框,用户输入姓名和年龄,点击【确定】返回,在主窗体表格中插入一行数据。

创建主窗体

为了方便起见使用QWdiget创建主窗体,当然你可以使用QMainWindow,用QTableView和QStandardItemModel来创建表格。

  1. classMainWindow(QtGui.QWidget):
  2. def __init__(self, parent=None):
  3. QtGui.QMainWindow.__init__(self, parent)
  4.  
  5. # 创建table和model
  6. table =QtGui.QTableView(parent=self)
  7. self.model =QtGui.QStandardItemModel(parent=self)
  8. self.model.setHorizontalHeaderLabels((u'姓名', u'年龄'))
  9. table.setModel(self.model)
  10.  
  11. # 创建添加按钮
  12. button =QtGui.QPushButton(u'添加', parent=self)
  13.  
  14. # 添加信号槽
  15. button.clicked.connect(self.add)
  16.  
  17. # 创建一个垂直布局,用于防止表格和按钮
  18. layout =QtGui.QVBoxLayout()
  19. layout.addWidget(table)
  20. layout.addWidget(button)
  21.  
  22. self.setLayout(layout)
  23.  
  24. def add(self):
  25. pass

创建对话框

对话框从QDialog继承,按钮这里使用QButtonBox来创建,用QButtonBox的好处是创建方便,定义参数即可,并且会自动根据不同平台显示按钮的位置,和各平台风格保持一致,当然默认是英文的,你可以通过国际化来做成中文的。

这里没有做对话框内容的验证,你可以覆盖QDialog的accept方法来进行验证。

下面是对话框的创建代码,为了方便获取姓名和年龄变量,我写了两个方法供外部调用。

  1. classDialog(QtGui.QDialog):
  2. def __init__(self, parent=None):
  3. QtGui.QDialog.__init__(self, parent)
  4. self.resize(240,200)
  5.  
  6. # 表格布局,用来布局QLabel和QLineEdit及QSpinBox
  7. grid =QtGui.QGridLayout()
  8.  
  9. grid.addWidget(QtGui.QLabel(u'姓名', parent=self),0,0,1,1)
  10.  
  11. self.leName =QtGui.QLineEdit(parent=self)
  12. grid.addWidget(self.leName,0,1,1,1)
  13.  
  14. grid.addWidget(QtGui.QLabel(u'年龄', parent=self),1,0,1,1)
  15.  
  16. self.sbAge =QtGui.QSpinBox(parent=self)
  17. grid.addWidget(self.sbAge,1,1,1,1)
  18.  
  19. # 创建ButtonBox,用户确定和取消
  20. buttonBox =QtGui.QDialogButtonBox(parent=self)
  21. buttonBox.setOrientation(QtCore.Qt.Horizontal)# 设置为水平方向
  22. buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)# 确定和取消两个按钮
  23. # 连接信号和槽
  24. buttonBox.accepted.connect(self.accept)# 确定
  25. buttonBox.rejected.connect(self.reject)# 取消
  26.  
  27. # 垂直布局,布局表格及按钮
  28. layout =QtGui.QVBoxLayout()
  29.  
  30. # 加入前面创建的表格布局
  31. layout.addLayout(grid)
  32.  
  33. # 放一个间隔对象美化布局
  34. spacerItem =QtGui.QSpacerItem(20,48,QtGui.QSizePolicy.Minimum,QtGui.QSizePolicy.Expanding)
  35. layout.addItem(spacerItem)
  36.  
  37. # ButtonBox
  38. layout.addWidget(buttonBox)
  39.  
  40. self.setLayout(layout)
  41.  
  42. def name(self):
  43. returnself.leName.text()
  44.  
  45. def age(self):
  46. returnself.sbAge.value()

编写对话框调用代码

调用对话框只要使用exec_方法即可,它会弹出对话框并根据用户操作返回值,根据返回值判断是【确定】还是【取消】。

  1. dialog =Dialog(parent=self)
  2. if dialog.exec_():
  3. self.model.appendRow((
  4. QtGui.QStandardItem(dialog.name()),
  5. QtGui.QStandardItem(str(dialog.age())),
  6. ))
  7.  
  8. dialog.destroy()

完整代码和截图

  1. # -*- coding: utf-8 -*-
  2. fromPyQt4importQtGui,QtCore
  3.  
  4. classMainWindow(QtGui.QWidget):
  5. def __init__(self, parent=None):
  6. QtGui.QMainWindow.__init__(self, parent)
  7.  
  8. # 创建table和model
  9. table =QtGui.QTableView(parent=self)
  10. self.model =QtGui.QStandardItemModel(parent=self)
  11. self.model.setHorizontalHeaderLabels((u'姓名', u'年龄'))
  12. table.setModel(self.model)
  13.  
  14. # 创建添加按钮
  15. button =QtGui.QPushButton(u'添加', parent=self)
  16.  
  17. # 添加信号槽
  18. button.clicked.connect(self.add)
  19.  
  20. # 创建一个垂直布局,用于防止表格和按钮
  21. layout =QtGui.QVBoxLayout()
  22. layout.addWidget(table)
  23. layout.addWidget(button)
  24.  
  25. self.setLayout(layout)
  26.  
  27. def add(self):
  28. dialog =Dialog(parent=self)
  29. if dialog.exec_():
  30. self.model.appendRow((
  31. QtGui.QStandardItem(dialog.name()),
  32. QtGui.QStandardItem(str(dialog.age())),
  33. ))
  34.  
  35. dialog.destroy()
  36.  
  37.  
  38. classDialog(QtGui.QDialog):
  39. def __init__(self, parent=None):
  40. QtGui.QDialog.__init__(self, parent)
  41. self.resize(240,200)
  42.  
  43. # 表格布局,用来布局QLabel和QLineEdit及QSpinBox
  44. grid =QtGui.QGridLayout()
  45.  
  46. grid.addWidget(QtGui.QLabel(u'姓名', parent=self),0,0,1,1)
  47.  
  48. self.leName =QtGui.QLineEdit(parent=self)
  49. grid.addWidget(self.leName,0,1,1,1)
  50.  
  51. grid.addWidget(QtGui.QLabel(u'年龄', parent=self),1,0,1,1)
  52.  
  53. self.sbAge =QtGui.QSpinBox(parent=self)
  54. grid.addWidget(self.sbAge,1,1,1,1)
  55.  
  56. # 创建ButtonBox,用户确定和取消
  57. buttonBox =QtGui.QDialogButtonBox(parent=self)
  58. buttonBox.setOrientation(QtCore.Qt.Horizontal)# 设置为水平方向
  59. buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)# 确定和取消两个按钮
  60. # 连接信号和槽
  61. buttonBox.accepted.connect(self.accept)# 确定
  62. buttonBox.rejected.connect(self.reject)# 取消
  63.  
  64. # 垂直布局,布局表格及按钮
  65. layout =QtGui.QVBoxLayout()
  66.  
  67. # 加入前面创建的表格布局
  68. layout.addLayout(grid)
  69.  
  70. # 放一个间隔对象美化布局
  71. spacerItem =QtGui.QSpacerItem(20,48,QtGui.QSizePolicy.Minimum,QtGui.QSizePolicy.Expanding)
  72. layout.addItem(spacerItem)
  73.  
  74. # ButtonBox
  75. layout.addWidget(buttonBox)
  76.  
  77. self.setLayout(layout)
  78.  
  79. def name(self):
  80. returnself.leName.text()
  81.  
  82. def age(self):
  83. returnself.sbAge.value()
  84.  
  85.  
  86. if __name__ =='__main__':
  87. import sys
  88. app =QtGui.QApplication(sys.argv)
  89. mainWindow =MainWindow()
  90. mainWindow.show()
  91. sys.exit(app.exec_())
http://jimmykuu.qiniudn.com/blog/9_1.jpg
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值