PyQt4的事件与信号

PyQt4的事件与信号

事件(event

事件由用户或者系统产生,当我们调用程序的exec_()方法时,程序进入主循环中。主循环就会捕捉事件并将它们发送给相应的对象进行处理。

 

信号与槽

 

其实信号和槽就是方法

 

当我们点击某个按钮,或者某个控件有动作,都会发送相应的信号。

 

信号可以自定义 利用 sender.emit(QtCore.SIGNAL("xxx自定义的信号"),receiver)

 

链接信号与槽的方法connect

PyQt4中对connect方法的申明有三种:

1、第一种:

bool QObject::connect ( const QObject * sender, const char * signal, const QObject * receiver, const char * method, Qt::ConnectionType type = Qt::AutoConnection ) [static]

5个参数:

QObject * sender----信号的发送者对象

char * signal-----------要发送的信号 QtCore.SIGNAL(‘发送的信号’)

QObject * receiver---信号接收者对象

char * method---------对信号做出响应的函数

Qt::ConnectionType—表示信号发送个槽的方式默认是AutoConnection

如果成功返回true

帮助文档的例子

A.        connect(scrollBar, SIGNAL(valueChanged(int)),label, SLOT(setNum(int))) scrollBar发送valueChanged(int)信号给labellabel执行setNum(int)方法

B.    connect(myButton, SIGNAL(clicked()), this, SIGNAL(buttonClicked()))即一个信号也可以传递给另一个信

 

2.第二种:

bool QObject::connect ( const QObject * sender, const QMetaMethod & signal, const QObject * receiver, const QMetaMethod & method, Qt::ConnectionType type = Qt::AutoConnection ) [static]

和第一种用法一样,只是用QMetaMethod来表示信号和方法

 

第三种:

bool QObject::connect ( const QObject * sender, const char * signal, const char * method, Qt::ConnectionType type = Qt::AutoConnection ) const

 

等价于connect(sender, signal, this, method, type)

一般你只需要传递(sender,signal,method)即可

 

一个简单实例

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

from PyQt4 import QtGui, QtCore

class Example(QtGui.QWidget):

    def __init__(self, parent=None):

        QtGui.QWidget.__init__(self, parent)

       

        self.setGeometry(300, 300, 400, 300)

        self.setWindowTitle("exmaple")     

        okbutton=QtGui.QPushButton('ok', self)

        okbutton.move(10, 10)

        self.connect(okbutton, QtCore.SIGNAL('clicked()'), QtGui.qApp, QtCore.SLOT('quit()'))

 

if __name__ == "__main__":

    import sys

    app = QtGui.QApplication(sys.argv)

    dialog = Example()

    dialog.show()

    sys.exit(app.exec_())

点击ok按钮,发出clicked()信号,对话框quit()槽响应退出

 

这些都是老式的形式,新式的API还没有学习,路漫漫其修远兮。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值