Event Delivery: The Responder Chain

当我们设计app的时候,我们很可能想动态的响应事件。例如,触摸一个拥有许多不同对象的屏幕,你要决定给哪个对象一个响应事件,怎么样对象接收到事件。

当一个用户产生事件发生时(如 点击),UIKit产生一个对象,这个包含要被处理的对象的信息。接着把事件对象放到active app‘s(一个application对象,负责初始化用户事件路由、从全局管理一个运行的application)事件队列中。对于触摸事件,这个对象是一组触摸,打包放在UIEvent对象。对motion事件而言,事件对象根据你使用框架的不同和你感兴趣的motion事件类型而有所差异。

一个事件对象沿一个明确的路径传递,直到有个对象可以处理它。首先,单例UIApplication对象从队列的顶部取一个事件,并进行分发处理。一般,UIApplication对象把事件发给应用的key window 对象,key window对象传递给一个initial对象来处理。这个initial对象取决于事件的类型。

  • Touch events。对于触摸事件,window对象首先尝试将事件发送给事件发生的view(hit-test view)。找到hit-test view的过程被称为hit-testing(我们将在后边谈到)。
  • Motioin and remote control enents。这类事件,window对虾ing发送shaking-motion或者remote control event给第一响应者处理。

事件路径(event paths)的终极目标是找到一个对象来处理响应一个事件。因此,UIKit首先把这个事件发送给最适合处理这个时间的对象。对于触摸事件,这个对象是hit-test view;对于其他事件,这个对象是第一响应者。下面的部分介绍关于确定hit-test view 和 第一响应者的更多细节。

Hit-Testing Returns the View Where a Touch Occurred(hit-test返回触摸发生的view)。有的地方翻译感觉很别扭,为了避免误导(真的有人看吗?),原文贴上。

iOS use hit-testing fo find the view that is under a touch. Hit-testing involves checking whether a touch is within the bounds fo any relevant(更多强调直接相关) view objects. If it is, it recursively checks all of that view‘s subviews. The lowest view in the view hierarchy that contains the touch point becomes the hit-test view. After iOS determines the hit-test view, it passes the touch event to that view for handling.

举例说明,假设用户在View E中触摸,iOS通过用下面的次序检查subviews来查找hit-test view:

  1. 触摸在view A的bounds内,所以检查subview B和C;
  2. 触摸不在View B的bounds内,但在View C的bounds内,所以检查subview D和E;
  3. 触摸不在View D的bounds内,但在view E的bounds内。
    View E is the lowest view in the view hierarchy that contains the touch, so it becomes the hit-test view.

hitTest:withEvent: 方法返回一个CGPoint和UIEvent的hit-test view。 hitTest:withEvent: 方法开始执行通过view本身调用 pointInside:withEvent: 方法。如果传入pointInside:withEvent:的点在view的bounds内,pointInside:withEvent:返回YES。接着,在这个view的每个subview上调用hitTest:withEvent:。

传入hitTest:withEvent:的点不在view的bounds中得情况不细说了。

注意:一个触摸事件在它的整个生命周期中和它的hit-test view相关联,即使稍后触摸移出了这个view。

hit-test view被给予了第一次来处理触摸事件的机会。如果hit-test view不能处理这个事件,事件将沿这个view的响应者链条往下走,直到找到一个可以处理事件的对象。

The Responder Chain Is Made Up of Responder Objects(响应者链条由响应者组成-。-)

许多类型的事件以来响应链条传递事件。响应者链条是一系列连起来的响应者对象。以第一响应者开始,结束语application对象。如果第一响应者不能处理一个事件,它就转发给响应者链条中的下一个响应者。

responder object is an object that can respond to and handle events. The  UIResponder  class is the base class for all responder objects, and it defines the programmatic interface not only for event handling but also for common responder behavior. Instances of the UIApplicationUIViewController, and UIView classes are responders, which means that all views and most key controller objects are responders. Note that Core Animation layers are not responders.

第一响应者被指定首先接受事件。通常,第一响应者是一个view对象。一个对象可以变成第一响应者通过做下面两件事:

  1. 重写 canBecomeFirstResponder 方法,返回YES;
  2. 接受一个 becomeFirstResponder 消息。如果必要,一个对象可以给自己发送这条消息。

依赖响应者链条的对象不止事件对象。响应者链条可以用在下面的地方:

  1. Touch events.
  2. Motion events.
  3. Remote control events.
  4. Action messages.
  5. Editing-menu messages.
  6. Text editing.

UIKit自动设置用户点击的text field 或 text view成为第一响应者;Apps必须显式设置所有其他的第一响应者,用becomeFirstResponder方法。

时间: 2024-10-10 02:38:30

Event Delivery: The Responder Chain的相关文章

【IOS笔记】Event Delivery: The Responder Chain

Event Delivery: The Responder Chain  事件分发--响应链 When you design your app, it’s likely that you want to respond to events dynamically. For example, a touch can occur in many different objects onscreen, and you have to decide which object you want to re

事件传递之响应链(Event Delivery: The Responder Chain)【转】

当你设计App时你可能需要动态的响应事件.例如,一个触摸事件可能发生在屏幕上不同的对象中,你需要决定哪个对象来响应这个给定的事件,理解对象如何接收事件. 当用户触发的一个事件发生,UIKit会创建一个包含要处理的事件信息的事件对象.然后她会将事件对象放入active app’s(应用程序对象,每个程序对应唯一一个)事件队列.对于触摸事件,事件对象就是UIevent对象封装的一系列触摸集合.对于动作事件,这个事件对象依赖于使用的framework和你关心哪种动作事件. 事件通过特殊的路径传递直到被

hitTest:WithEvent 和Responder Chain

这个方法是找到那个View被touch,当找到后就成为响应链的第一个了,如果他不能处理这个Event,那么就找nextResponder 直至application 如果不能处理,那就会丢弃掉. https://developer.apple.com/library/ios/documentation/EventHandling/Conceptual/EventHandlingiPhoneOS/event_delivery_responder_chain/event_delivery_respo

iOS - Responder Chain

 在iOS中,当发生事件响应时,必须知道由谁来响应事件.这就是由响应者链来对事件进行响应,所有事件响应的类都是UIResponder的子类,响应者链是一个由不同对象组成的层次结构,其中的每个对象将依次获得响应事件消息的机会.当发生事件时,事件首先被发送给第一响应者,第一响应者往往是事件发生的视图,也就是用户触摸屏幕的地方.事件将沿着响应者链一直向下传递,直到被接受并作出处理. 一般来说,第一响应者是个视图对象或者其子类对象,当其被触摸后事件交由他处理,如果他不处理,事件就会被传递给它的视图控制器

iOS Responder Chain 响应者链

一.事件分类 对于IOS设备用户来说,他们操作设备的方式主要有三种:触摸屏幕.晃动设备.通过遥控设施控制设备.对应的事件类型有以下三种: 1.触屏事件(Touch Event) 2.运动事件(Motion Event) 3.远端控制事件(Remote-Control Event) 今天以触屏事件(Touch Event)为例,来说明在Cocoa Touch框架中,事件的处理流程.首先不得不先介绍响应者链这个概念: 二.响应者链(Responder Chain) 先来说说响应者对象(Respond

ios中事件的响应链(Responder chain)和传递链

事件的响应链涉及到的一些概念 UIResponder类,是UIKIT中一个用于处理事件响应的基类.窗又上的所有事件触发,都由该类响应(即事件处理入又).所以,窗又上的View及控制器都是 派生于该类的,例如UIView.UIViewController等. 调用UIResponder类提供的方法或属性,我们就可以捕捉到窗又上的所有响应 事件,并进行处理. 响应者链条是由多个响应者对象连接起来的链条,其中响应者对象是能处理事 件的对象,所有的View和ViewController都是响应者对象,利

View Controller Programming Guide for iOS---(八)---Using View Controllers in the Responder Chain

Using View Controllers in the Responder Chain 响应链中使用视图控制器 View controllers are descendants of the UIResponder class and are therefore capable of handling all sorts of events. When a view does not respond to a given event, it passes that event to its

iOS开发——响应链(Responder Chain)的深入理解和代码示例

我在之前一篇博客<iOS响应者链Responder Chain浅析>中对iOS开发中遇到的响应者链概念有了基本的了解.但是仅仅停留在理解概念的基础上还是远远不够的.该博客我们会通过代码案例来深入理解响应链.该博客的示例上传至 https://github.com/chenyufeng1991/ResponderChain  . (1)首先来说说第一响应者(First Responder).响应事件的传递过程就是为了找到第一响应者.以下几个方法: isFirstResponder:判断该View

iOS开发——响应链(Responder Chain)的深入理解和代码示例(二)

响应链机制是开发中很重要的概念,在一些事件的处理中需要对响应链的传递有深入的了解,我们才能对事件的传递有更好的控制.今天我们继续来研究下响应链,并实现一个很简单的功能.示例代码已经上传至 https://github.com/chenyufeng1991/HitTest ,可以进行下载调试.要实现的一个很简单的功能就是:透过顶部视图,让底部视图来响应点击事件,这也会响应链使用中非常重要的应用.下面也会涉及一些不同的案例.用到最常用的方法为hitTest:withEvent和pointInside