PyQt 中实例讲解对__init__(self,parent==None)中的 parent理解

parent作用

在PyQt中,所有class都是从QObject派生而来,QWidget对象就可以有一个parent。这种parent-child关系主要用于两个方面:

  1. 没有parent的QWidget类被认为是最上层的窗体(通常是MainWindow),由于MainWindow的一些操作生成的新窗体对象,parent都应该指向MainWindow。
  2. 由于parent-child关系的存在,它保证了child窗体在主窗体被回收之时也被回收。

parent作为构造函数的最后一个参数被传入,但通常情况下不必显示去指定parent对象。因为当调用局管理器时,部局管理器会自动处理这种parent-child关系。但是在一些特殊的情况下,我们必须显示的指定parent-child关系。如当生成的子类不是QWidget对象但继承了QObject对象,用作dock widgets的QWidget对象。

我们可以看到,对象之间有了依赖和生命周期,把IOC容器运用到GUI编程中是自然而然的事情了。

实例讲解

示例说明:

新建三个文件,分别为 calc.uicalc_logic.pymain.py。其中:

  • calc.ui 为Ui设计文件, 需要转换为calc.py ;
  • calc_logic.py 是calc的实现逻辑部分;
  • main.py 是项目的主入口文件。

calc.ui

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>calc</class>
 <widget class="QWidget" name="calc">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>400</width>
    <height>300</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Form</string>
  </property>
  <widget class="QPushButton" name="pushButton_ok">
   <property name="geometry">
    <rect>
     <x>130</x>
     <y>160</y>
     <width>75</width>
     <height>23</height>
    </rect>
   </property>
   <property name="text">
    <string>提示</string>
   </property>
  </widget>
 </widget>
 <resources/>
 <connections/>
</ui>

 我们将calc.ui 转换为calc.py文件:

calc.py

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'calc.ui'
#
# Created: Wed Jan 28 11:28:59 2015
#      by: PyQt4 UI code generator 4.10.3
#
# WARNING! All changes made in this file will be lost!

from PyQt4 import QtCore, QtGui

try:
    _fromUtf8 = QtCore.QString.fromUtf8
except AttributeError:
    def _fromUtf8(s):
        return s

try:
    _encoding = QtGui.QApplication.UnicodeUTF8
    def _translate(context, text, disambig):
        return QtGui.QApplication.translate(context, text, disambig, _encoding)
except AttributeError:
    def _translate(context, text, disambig):
        return QtGui.QApplication.translate(context, text, disambig)

class Ui_calc(object):
    def setupUi(self, calc):
        calc.setObjectName(_fromUtf8("calc"))
        calc.resize(400, 300)
        self.pushButton_ok = QtGui.QPushButton(calc)
        self.pushButton_ok.setGeometry(QtCore.QRect(130, 160, 75, 23))
        self.pushButton_ok.setObjectName(_fromUtf8("pushButton_ok"))

        self.retranslateUi(calc)
        QtCore.QMetaObject.connectSlotsByName(calc)

    def retranslateUi(self, calc):
        calc.setWindowTitle(_translate("calc", "Form", None))
        self.pushButton_ok.setText(_translate("calc", "提示", None))


if __name__ == "__main__":
    import sys
    app = QtGui.QApplication(sys.argv)
    calc = QtGui.QWidget()
    ui = Ui_calc()
    ui.setupUi(calc)
    calc.show()
    sys.exit(app.exec_())

新建calc_logic.py 文件,文件内容:

calc_logic.py

# -*- coding: utf-8 -*-
from  PyQt4 import  QtGui, QtCore
from  calc import  Ui_calc  # 引入Ui



class calc_logic(QtGui.QWidget):
    def __init__(self,parent=None):
        super(calc_logic,self).__init__(parent)
        self.Ui=Ui_calc()  # 实例化 Ui
        self.Ui.setupUi(self) # 初始化Ui
        self.setWindowTitle('calc_logic Widget')

        self.connect(self.Ui.pushButton_ok,QtCore.SIGNAL('clicked()'),self.dialogx)

    def dialogx(self):
        if __name__=='__main__':
            QtGui.QMessageBox.information(self, (u'提示'),(u'  来自calc_logic文件请求!     '),QtGui.QMessageBox.Yes )
        elif __name__=='calc_logic':
            QtGui.QMessageBox.information(self, (u'提示'),(u'  来自main文件请求!     '),QtGui.QMessageBox.Yes )


if __name__ == "__main__":
    import sys
    app = QtGui.QApplication(sys.argv)
    calc =calc_logic()
    calc.show()
    sys.exit(app.exec_())

新建入口文件main.py:

main.py

# -*- coding: utf-8 -*-
'''
 main 主文件
'''
from  PyQt4 import  QtGui
import sys
from calc_logic import calc_logic   # 引入Ui的逻辑文件


class maincalc(QtGui.QWidget):
    def __init__(self):
        super(maincalc,self).__init__()
        self.setWindowTitle('main Widget')
        self.Ui=calc_logic(self) # 实例化 calc_logic

if __name__ == "__main__":
    import sys
    app = QtGui.QApplication(sys.argv)
    appcalc =maincalc()
    appcalc.show()
    sys.exit(app.exec_())

(1)情形1

我们先运行calc_logic.py ,得到结果:

关键语句在于:

mian.py中的

self.Ui=calc_logic(self)

clac_logic.py中的:

def __init__(self,parent=None):
        super(calc_logic,self).__init__(parent)

 

(2)情形2

然后修改calc_logic.py 中__init__初始方法,由

def __init__(self,parent=None):
         super(calc_logic,self).__init__(parent)

改为:

def __init__(self):
       super(calc_logic,self).__init__()

修改main.py 初始化calc_logic,由

self.Ui=calc_logic(self) # 实例化 calc_logic

改为:

self.Ui=calc_logic()

 得到结果为:

(3)总结

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

David-Chow

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值