iOS11下底部长按手势的问题

最近在开发一个简单的功能时,被iOS11系统坑了一把,在此做个记录,后续尝试研究这个问题的解决方案

问题已解决,需要的小伙伴拿去

简单描述下问题:
有一个UIButton,需要同时监听UIControlEventTouchDownUIControlEventTouchUpInside的事件响应,以便在长按时做相应的业务处理,这个button的定位是底部是对齐屏幕的底部。然后诡异的事情就发生了,button的上半部分能正常的速度响应这个touchdown的事件,而下半部分需要等待2s左右时间😢😢😢

然而这个问题按照正常的逻辑去排查原因的话你只会发现根本无法理解,本着探索的精神,接下来我经历了一段长时间懵逼的研究探索:

  • 图层关系没问题,无遮挡无超出superview,而且事件也能响应,所以跟这个没什么关系
  • 新建了一个button,做同样的响应处理,放在同一水平线上(对比之前的button看有没有隐藏的坑),然并卵
  • 复制一模一样的button,放到靠上的位置,就正常了。。摸头中,难道我手机有问题,底部区域屏幕不太好用了?拿来另外一台手机测试,无果

到这里基本上确定了就是将button定位到底部区域才出现这样的问题,但一时间想不出个所以然,所以按以往的惯例,我碰到这种问题的做法都是,先睡一觉,明天就好了!

恩,今天就从调整frame入手,把button放在scrollview上,一点一点拖动看效果,最终发现是距离底部大概30pt的地方,蜜汁反应慢。。突然一下清醒,拿来上古时代的iphone5一测试,哈哈,哈哈。就是跟iOS系统有关啊。。具体的就不说啦,相信大家都知道是iPhoneX的底部手势区域,还没去做iPhoneX适配的我就这样踩进了这么个巨坑!!


12.14继续更新

在iPhoneX上Home Indicator作为系统级别的手势,理论上不应该对非iPhoneX的iPhone手机造成影响,觉得这应该是被苹果所忽略的bug。但作为开发者怎么样也得把自己先把这个坑给填了。
解决办法很简单,WWDC 2017之后对UIKit在iOS系统下新增了一些API,下面这个值得注意

- (UIRectEdge)preferredScreenEdgesDeferringSystemGestures

这个方法表明了屏幕边缘的手势动作(Screen Edge Gesture),一般来说都是由系统管理的,在控制器下重写这个方法,可以让自己的手势优先被调用,在这里的遇到的实际情况,我们应该使用UIRectEdgeBottom这个枚举值,问题完美解决😁


2018.1.2更新 大家新年快乐~
近期有小伙伴反应说,以上方法放在自己项目里无效,今天花了些时间研究,基本上可以确定是开启了侧滑返回手势导致的,会发现屏幕的中间以左的底部区域还是无法正常工作,目前还没有完整的解决方案,可以考虑先禁用掉当前页面的返回手势,也同样能解决问题,看如何取舍吧,当然其他小伙伴有招的也可以支个招,毕竟此种方法也是指标不治本😊😊

self.navigationController.interactivePopGestureRecognizer.enabled = NO;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 好奇触摸事件是如何从屏幕转移到APP内的?困惑于Cell怎么突然不能点击了?纠结于如何实现这个奇葩响应需求?亦或是...
    Lotheve阅读 58,256评论 51 603
  • 在iOS开发中经常会涉及到触摸事件。本想自己总结一下,但是遇到了这篇文章,感觉总结的已经很到位,特此转载。作者:L...
    WQ_UESTC阅读 6,140评论 4 26
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,714评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,261评论 4 61
  • 学习温庭筠的望江南,短短二十七个字,学生暗喜,好背好背,一切以考试为目的古诗词学习,都是对古圣先贤的亵渎,这首...
    大漠风阅读 319评论 1 5