监听事件:事件指点击,触摸这样的手势所引发的消息,监听事件即监听这类消息。
监听事件的目的是处理这类消息。
监听产生的目的是处理响应者影响范围的问题。
现在,假设我点击按钮,那么系统会发送一个触摸事件给按钮控件对象,按钮对象是作为事件的第一接收者的,但是现在我需要应用程序对我点击按钮作出如下反应:更改一个标签的值。
显然,按钮的作用域是无法涉及到标签的,那怎么办?找一个更大的作用域咯,比如UIViewController视图控制器对象,但,事件又不是发送给UIViewController 对象的,因此,就监听按钮控件,一旦按钮控件接收到相应事件,由UIViewController监听者作出反应,而按钮控件只是作为一个接收者,仅此而已。
- 继承自 UIControl 的类都满足 Target-Action 模式。
- 非以上的类可以使用协议代理的方式来监听事件。
Target-Action
01. ...
02. //UIControl类中定义了一个添加监听的方法
03. - (void)addTarget:(id)target action:(Sel) forControlEvents:(UIControlEvents)controlEvents
04. //@Parameter
05. //P1:监听者,UIControl类都是作为被监听者
06. //P2:监听到相应事件时的动作
07. //P3:要监听的事件类型
08. ...
栗子:
01. ...
02. //对一个按钮添加监听
03. [btn addTarget:self action:@selector(pressdown) forControlEvents:UIControlTouchDown];
04. //P1:被监听的对象是按钮,监听器是UIViewController根视图控制器对象
05. //P2:监听到点击事件时的处理
06. //P3:被监听的事件的类型是点击屏幕
07. //整个过程是:
08. //用户触摸到屏幕的瞬间,系统发送一个相应的事件到应用程序的第一响应者
09. //这里按钮控件是第一响应者,紧接着被根视图控制器监听到,判断消息是否是UIControlTouchDown事件类型
10. //是,监听者self执行处理pressdown,否,不做处理
11. ...
协议代理
协议代理的方式进行监听,理由也是一样,在于影响域,只不过监听的方式有些差异,不是Target-Action模式,而是通过Delegate属性通信的方式。
01. ...
02. // 比如滚动视图UIScrollView
03. @interface ViewController <UIScrollViewDelegate>
04. // 监听者接受协议
05. ...
06. UIScrollView对象.delegate = self;
07. //成为代理方和监听者
08. //选择合适的协议方法进行实现,达到监听的目的
09. - (void)scrollViewDidScroll:(UIScrollView *)scrollView{
10. // 监听到滚动消息时应用程序的处理
11. }
12. ...