iOS事件传递、响应者链、hitTest、pointInside

一、什么是事件传递

发生触摸事件后,系统会将该事件加入到一个由UIApplication管理的事件队列中,并将事件分发下去以便处理。通常,会先发送事件给应用程序的keyWindow,主窗口会在其视图层次结构中找到一个最合适的视图来处理触摸事件,这个找寻的过程就是事件传递

二、事件传递的过程

  • 1.事件传递的方向。
    window -> 父视图 -> 子视图 - >子视图的子视图
    我们可以这个方向简单理解成从内到外

  • 2.两个关键函数
    首先我们先来了解两个系统函数。
    1.pointInside:withEvent:

    - (BOOL)pointInside:(CGPoint)point withEvent:(nullable UIEvent *)event;
    

    这个方法是UIView用来判断点击事件发生的位置是否在当前视图范围内。

    2.hitTest:withEvent:

    // point是该视图的坐标系上的点
    - (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event
    {
      // 1.判断自己能否接收触摸事件
      if (self.userInteractionEnabled == NO || self.hidden == YES || self.alpha <= 0.01) return nil;
      // 2.判断触摸点在不在自己范围内
      if (![self pointInside:point withEvent:event]) return nil;
      // 3.从后往前遍历自己的子控件,看是否有子控件更适合响应此事件
      int count = self.subviews.count;
      for (int i = count - 1; i >= 0; i--) {
          UIView *childView = self.subviews[i];
          CGPoint childPoint = [self convertPoint:point toView:childView];
          UIView *fitView = [childView hitTest:childPoint withEvent:event];
          if (fitView) {
              return fitView;
          }
      }
      // 没有找到比自己更合适的view
      return self;
    }
    
    

    以上是hitTest:withEvent:的底层实现,这个方法在内部总共会经过三个步骤:
    1.首先会判断该视图是否能响应触摸事件,如果不能响应,返回nil,表示该视图不响应此触摸事件。
    2.调用pointInside:withEvent:(该方法用来判断点击事件发生的位置是否处于当前视图范围内)。如果pointInside:withEvent:返回NO,那么hiteTest:withEvent:也直接返回nil。
    3.如果pointInside:withEvent:返回YES,则向当前视图的所有子视图发送hitTest:withEvent:消息,所有子视图的遍历顺序是从最顶层视图一直到到最底层视图,即从subviews数组的末尾向前遍历。(这个遍历的过程可理解为从外到里)直到有子视图返回非空对象或者全部子视图遍历完毕;
    若第一次有子视图返回非空对象,则 hitTest:withEvent:方法返回此对象,该对象再继续1,2,3的步骤;
    若所有子视图都返回非,则hitTest:withEvent:方法返回该视图自身,说明事件传递到此结束,已经找到了最合适的视图来处理触摸事件。

三、响应者链

响应者:继承UIResponder的对象称之为响应者对象,能够处理touchesBegan等触摸事件。
响应者链:由很多响应者链接在一起组合起来的一个链条称之为响应者链条

每个能执行hitTest:方法的view都属于事件传递的一部分,但是,只有pointInside返回YES的view才属于响应者链条

通过事件传递找到最合适的处理触摸事件的view后,它就是第一响应者。所以事件传递是自下而上,而响应者链是自上而下的。(window上最外面的那个view称为上)

四、实际应用

1、扩大响应范围;
2、根据响应者链找到当前的controller;
3、截获事件,让需要的view去响应这个事件;
等等。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 用户以多种方式操纵他们的iOS设备,例如触摸屏幕或摇动设备。 iOS会解释用户何时以及如何操作硬件并将此信息传递到...
    坤坤同学阅读 3,984评论 7 19
  • 1、响应链的传递 Responder一点也不神秘————iOS用户响应者链完全剖析(建议全看)看完上面一篇应该能完...
    RasonWu阅读 10,373评论 3 36
  • 前言: 在咱们平时的开发过程中,每天都在敲着带有各种响应事件的代码,那咱们iOS的响应事件是怎样传递的呢?系统是怎...
    圣僧留步阅读 361评论 0 0
  • iOS中加载的时候会先执行main函数 int main(int argc, charchar * argv[])...
    Ven415阅读 283评论 0 0
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 7,517评论 16 22