1.简介

  寻找处理触摸事件的view的过程为hit-testing,找到的能够处理触摸事件的view叫做hit-test view。

2.机制介绍

  假设下图为我们的手机屏幕,当我们假设点击了view E那么他的整个寻找过程是这样的:

  1.点击点坐标是在 View A区域,所以讲会继续检查View A的subview View B和View C

  2.发现点击点坐标不再view B区域而是在View C区域,所以将会继续检查View C的subview View D和View E

  3.点击点不在View D区域,但是他在View E区域,于是去检查View E的subview,但是发现VIew B已经没有subview,于是View B被确定为hit-test view

  

从代码上来说,它主要执行了UIView的- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event方法,内部是调用

-(BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event方法,

1.如果当前传入的point在当前UIView对象的bounds范围内则返回true,

随后在所有只要-(BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event方法返回为true的subview上递归调用- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event方法直到最终找出hit-test view

用代码来描述的话好比是这样:

-(UIView *) hitTest:(CGPoint)point withEvent:(UIEvent *)event {
    // 如果point在当前view的bounds中
    if ([self pointInside:point withEvent:event]) {
        // 在所有其subview上去寻找hit-test view
        for (UIView *view in self.subviews) {
           return  [view hitTest:point withEvent:event];
        }
    }
}

2.如果当前传入的point不再当前UIView对象的bounds范围内则返回false

那么当前- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event方法将返回nil,此后所有其subview的检查都将忽略,应为如果point不再superview上那么肯定

不再subview上。

这样我们就找到了hit-test view来处理事件,但是但是但是这个hit-test view根本就不关心这个事件(没有覆盖相关方法)则这个事件将被扔进响应者链中寻找主人了~~

 3.特殊情况clipsToBounds

clipsTonbounds是设置subview超出superview的部分是否裁剪掉的属性,此属性是设置在superView上的。

NO(默认):

YES:

那么问题来了,如果我们点击超出黄色部分的红色区域会触发touch事件吗?

也就说点击不再superView区域的subView区域。

证明:

1.新建UIView子类,作用于当前subView(红色块)上:

#import "XFSubView.h"

@implementation XFSubView

-(void) touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    NSLog(@"%@", @"Do touchBegan!");
}

-(void) touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    [super touchesMoved:touches withEvent:event];
}

-(void) touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    [super touchesEnded:touches withEvent:event];
}

-(void) touchesCancelled:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    [super touchesCancelled:touches withEvent:event];
}
@end

2.点击黄色区域范围内的红色区域:

结果:打印日志。

3.点击黄色区域范围外的红色区域:

结果:不打印日志。

总结:即使是父子关系的view,只有子view的范围在父view的范围内的控件部分才能接受touch事件。

hit-testing机制介绍的更多相关文章

  1. iOS 阶段学习第25天笔记(iOS沙盒机制介绍)

    iOS学习(OC语言)知识点整理 一.iOS沙盒机制介绍 1)概念: 每个ios应用都有自己的应用沙盒,应用沙盒就是文件系统目录,与其他应用放入文件 系统隔离,ios系统不允许访问 其他应用的应用沙盒 ...

  2. iOS沙盒机制介绍,Block 的介绍

    一.iOS沙盒机制介绍 (转载) 1)概念:每个ios应用都有自己的应用沙盒,应用沙盒就是文件系统目录,与其他应用放入文件 系统隔离,ios系统不允许访问 其他应用的应用沙盒,但在ios8中已经开放访 ...

  3. Linux 内核的文件 Cache 管理机制介绍

    Linux 内核的文件 Cache 管理机制介绍 http://www.ibm.com/developerworks/cn/linux/l-cache/ 1 前言 自从诞生以来,Linux 就被不断完 ...

  4. Mysql锁机制介绍

    Mysql锁机制介绍 一.概况MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制.比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking ...

  5. Html5 Canvas Hit Testing

    名词解释: Shape : 矢量图形,点线面之类的: Hit Testing : 点击测试: 参考内容: A Gentle Introduction to Making HTML5 Canvas In ...

  6. redis锁机制介绍与实例

    转自:https://m.jb51.net/article/154421.htm 今天小编就为大家分享一篇关于redis锁机制介绍与实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要 ...

  7. 线程安全的集合类、CopyOnWrite机制介绍(转)

    看过并发编程的书,这两种机制都有所了解,但不扎实其实.看到别人的博客描述的很精辟,于是转过来,感谢! 原文链接:https://blog.csdn.net/yen_csdn/article/detai ...

  8. nginx基本配置与参数说明以及Nginx中的upstream轮询机制介绍

    转自:http://blog.csdn.net/happydream_c/article/details/54943802 一.nginx简介 Nginx (发音为[engine x])专为性能优化而 ...

  9. Binder通信机制介绍

    1.Binder通信机制介绍 这篇文章会先对比Binder机制与Linux的通信机制的差别,了解为什么Android会另起炉灶,采用Binder.接着,会根据 Binder的机制,去理解什么是Serv ...

随机推荐

  1. (五)Redis集合Set操作

    Set全部命令如下: sadd key member1 member2 ... # 将一个或多个member元素加入到集合key中,已经存在于集合的member元素将被忽略 spop key # 移除 ...

  2. [洛谷P3261][JLOI2015]城池攻占

    题目大意:有$n$个点的树,第$i$个节点有一个权值$h_i$,$m$个骑士,第$i$个骑士攻击力为$v_i$,一个骑士可以把从它开始的连续的父亲中比它小的节点攻破,攻破一个节点可以把攻击力加或乘一个 ...

  3. BZOJ4518:[SDOI2016]征途——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4518 https://www.luogu.org/problemnew/show/P4072 Pi ...

  4. MEMCACHE用法详解

    MemCache是一个自由.源码开放.高性能.分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问的速度. Me ...

  5. CSS的历史与工作原理

    1. 浏览器的发展与CSS 网页浏览器主要通过HTTP协议连接网页服务器而取得网页,HTTP容许网页浏览器送交资料到网页服务器并且获取网页.目前最常用的 HTTP 是 HTTP/1.1,这个协议在RF ...

  6. bzoj 2086 [Poi2010]Blocks 单调栈

    [Poi2010]Blocks Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 788  Solved: 356[Submit][Status][Dis ...

  7. Bigbluebutton安装过程

    BigBlueButton安装过程(翻译) 欢迎来到BigBlueButton 1.0-beta安装指南(以下简称BigBlueButton 1.0).BigBlueButton是一个开放源代码的网络 ...

  8. C语言数组与指针总结

    寒假要开始猛刷<剑指offer>,先回顾一下C语言基础做个热身. 指针 相信大家对下面的代码不陌生: ; int *p; p=&i; 这是最简单的指针应用,也是最基本的用法.再来熟 ...

  9. easing.js让页面动画丰富起来

    jQuery Easing是一款比较老的jQuery插件,在很多网站都有应用,尤其是在一些页面滚动.幻灯片切换等场景应用比较多.它非常小巧,且有多种动画方案供选择,使用简单,而且免费. <scr ...

  10. mpvue开发小记

    1.组件嵌套组件时,子组件作用域bug 组件A内的slot包含子组件B的话,无法正常使用变量(这种情况下,B组件的template错误地使用了A的作用域). 我的解决方案:减少一层组件提炼,即这种情况 ...