iOS 12:modal、事件传递与处理、手势

Modal

  • 除了push之外,这是另外一种控制器的切换方式
  • 任何控制器都能通过Model的形式展示出来
  • 以Model 的形式展示控制器:presentViewController:
  • 关闭当初Model出来的控制器:dismissViewControllerAnimated:
  • 使用时机:前后两个控制器没有多少信息逻辑上的关连时;当前后控制器有明显逻辑上的层级关系时,用 UINavigationController 和 push
  • modal出谁,谁就有权利dismiss
  • 谁modal控制器,谁也有权利dismiss

iOS 中的事件

  • 在用户使用app过程中,会产生各种各样的事件
  • 大体分为3大类型
    • 1.触摸事件
    • 2.加速计事件
    • 3.远程控制事件
  • 响应者对象:在iOS中不是任何对象都能处理事件,只有继承了UIResponder的对象才能接收并处理事件
  • UIApplicaiton UIViewController UIView 都继承自 UIResponder,因此它们都是响应者对象,都能够接收并处理事件。
图片 12.png
  • UITouch
    • 当用户用一根手指触摸屏幕时,会创建一个与手指相关连的UITouch对象
    • 一根手指对应一个UITouch对象
    • UTouch 的作用:保存着跟手指相关的信息,比如触摸的位置、时间、阶段
    • 当手指移动时,系统会更新同一个UITouch对象,使之能够一直保存该手指在的触摸位置
    • 当手指离开屏幕时,系统会销毁相应的UITouch对象。
  • UIEvent
    • 每产生一个事件,就会产生一个UIEvent对象
    • UIEvent:称为事件对象,记录事件产生的时刻和类型。
    • UIEvent还提供了相应的方法可以获得在某个view上面的磋磨对象UITouch
图片 13.png

事件的产生与传递

  • 产生与传递过程

    • 发生触摸事件后,系统会将该事件加入到一个由UIApplicaiton管理的事件队列中。
    • UIApplication会从事件队列中取出最前面的事件,并将事件分发下去以便处理。通常,先发送事件给应用程序的主窗口(keyWindow)
    • 主窗口会在视图层次结构中找到一个最合适的视图来处理触摸事件,这也是整个事件过程的第一步
    • 找到合适的视图控件后,就会调用视图控件的touches方法来作具体的事件处理。
  • 触摸事件的传递从父控件传递到子控件。

  • 如果父控件不接受触摸事件,那么子控件也不会接受触摸事件。

  • 如何找到最合适的控件来处理事件

    • 1.自己能否接收触摸事件
    • 2.触摸点是否在自己身上
    • 3.从后往前遍历子控件,重复前面的2个步骤
    • 4.如果没有符合条件的子控件,那么就自己最适合处理
  • UIView不接受触摸事件的3中情况

    • 1.userInterationEnabled = NO
    • 2.hidden = YES
    • 3.alpha = 0 ~ 0.01
    • UIImageView的 userInterationEnabled默认是 NO

hitTest、pointInside

  • 什么时候调用:当事件传递给控件的时候,就会调用控件的这个方法。
  • hitTest作用:为了寻找最合适的view
  • 重写该方法,可以改变事件本来的传递与处理流程
  • 底层实现:递归
  • point:当前的触摸点,point这个点的坐标系就是方法调用者
  • pointInside:判断当前的触摸点是否在不在方法调用者上?
  • 子控件超过父控件,是不能够处理事件的,除非重写hitTest:方法。

响应者链条

  • 定义:是由多个响应者对象连接起来的链条
  • 作用:能很清楚的看见每个响应者之间的联系,并且可以让一个时间多个对象处理
  • 响应者对象:能处理事件的对象
图片 15.png
  • 事件传递的完整过程
图片 16.png
  • 响应者链的事件传递过程
    • 如果view的控制器存在,就传递给控制器;如果控制器不存在,则将其传递给它的父视图
    • 在视图层次结构的最顶级视图,如果也不能处理收到的事件或消息,则其将事件或消息传递给window对象进行处理
    • 如果window对象也不处理,则其将事件或消息传递给UIApplication对象
    • 如果UIApplication也不能处理该事件或消息,则将其丢弃

手势识别

  • 利用UIGestureRecognizer,能轻松识别用户在某个view上面做的一些常见手势
  • 手势种类
    • 1.点按 tap
    • 2.长按 longPress 长按手势,默认触发两次
    • 3.轻扫 swipe 默认轻扫的方向是从左 ——> 右;如果以后想要一个控件支持多个方向的轻扫,必须创建多个轻扫手势,一个轻扫手势只支持一个方向
    • 4.旋转 rotation 默认传递的旋转的角度是相对于最开始的位置
    • 5.缩放 scale
    • 6.拖拽 pan
  • 默认不支持多个手势,需要遵守协议 < UIGestureRecognizerDelegate > ,重写方法。
  • 协议中的方法包含有:是否允许触发手势,是否允许手指的触摸点(可以实现手势区域触发)

tips:

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

推荐阅读更多精彩内容