码迷,mamicode.com
首页 > 其他好文 > 详细

QT信号槽与Delphi事件的对比

时间:2014-08-11 20:46:52      阅读:1061      评论:0      收藏:0      [点我收藏+]

标签:style   color   os   strong   文件   ar   window   设计   

最近学QT,对信号槽机制感到有点新鲜:

QObject::connect(slider, SIGNAL(valueChanged(int)), lcd, SLOT(display(int)));

自己总结其原理,就是一句话:把两个对象的函数相关(往往是设置同一个值),而不用考虑两个对象之间的关系,而且可以一对多发信号。缺点是,事先要规定哪些函数可以信号,哪些函数是槽。而且执行内容貌似有点单调。

 

这一机制号称先进,但Delphi里其实也有,而且应该更强大,因为信号源可以任意指定。而且设计时可以,动态改变也行。设计的时候,其机制被存储在.dfm文件里:

object Edit1: TEdit
Left = 136
Top = 80
Width = 121
Height = 21
TabOrder = 0
Text = ‘Edit1‘
OnChange = Edit1Change
OnClick = Edit1Click
end

这是可视化设计的做法。如果忘了这么做,动态写语句也可以,而且就一句话:

    Edit1.OnClick := Button2Click (以OnClick事件为例,注意它不是OnMouseDown和OnMouseUp事件,但它们之间也有一定的联系。OnClick事件实际上是由OnMouseUp函数来执行的)

缺点是,必须要事先定义FOnClick这个事件,其类型是定义在TControl里的 FOnClick: TNotifyEvent; 也就是必须事先定义槽。至于信号无所谓,只要参数一致即可(我猜测,通过复杂的语法变幻,没准参数都不必一致)。定义了槽就可以随时动态插拔要执行的函数,真是方便:

procedure TControl.Click;
begin
if Assigned(FOnClick) then
FOnClick(Self);
end;

通过调用Click这个专门检查槽和执行槽的函数,达到触发槽的目的。但是还不够,触发前后肯定要做一堆事情,并且要加上条件判断才行,看这里:

procedure TControl.WMLButtonUp(var Message: TWMLButtonUp);
begin
inherited; // 怪异,为什么要先执行这个?
if csCaptureMouse in ControlStyle then MouseCapture := False;
if csClicked in ControlState then
begin
Exclude(FControlState, csClicked);
if PtInRect(ClientRect, SmallPointToPoint(Message.Pos)) then Click;
end;
DoMouseUp(Message, mbLeft);
end;

但是到底谁来触发这个槽呢(第一驱动力)?Windows下说到底是要靠消息来触发,所以就很简单啦:

procedure WMLButtonUp(var Message: TWMLButtonUp); message WM_LBUTTONUP;

QT信号槽与Delphi事件的对比,布布扣,bubuko.com

QT信号槽与Delphi事件的对比

标签:style   color   os   strong   文件   ar   window   设计   

原文地址:http://www.cnblogs.com/findumars/p/3905212.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!