转自:https://blog.csdn.net/haha223545/article/details/80259217
第1部分:说明
最近在做一个类似微信语音聊天的功能,在屏幕的底部放一个Button,按下时可以语音说话,松开时将语音发出去。但是做的过程中遇到一个坑:按钮放到页面最底部的时候会延迟touchDown事件。
第2部分:解决步骤
- 在网上找了一些回答,好多都是说受到TableView或ScrollView的影响,但尝试去掉TableView后依然没有解决。
- 考虑是不是UI层级太深,影响到事件的响应,尝试减少到一个层级后依赖无效。
- 后来干脆新建了一个UIViewController,页面上只放了一个UIButton,去掉任何多余的代码(这样可以不排队其它因素的干扰)发现还是有问题。
- 设想是不是Button只放到底部才有问题,果断尝试将Button放到屏幕的上面、中间、下面测试,发现只有有下面的会延迟touchDown。又尝试将该按钮往上移动一点点,发现往上移动二三十的距离的时候就没有问题了。这个时候果断猜测是系统的一个坑。
- 经过了解是WWDC 2017之后对UIKit在iOS系统下新增了一些API:
- (UIRectEdge)preferredScreenEdgesDeferringSystemGestures API_AVAILABLE(ios(11.0)) API_UNAVAILABLE(watchos, tvos);
- 1
该方法表示屏幕边缘的手势动作(Screen Edge Gesture),一般来说都是由系统管理的,在控制器下重写这个方法,可以让自己的手势优先被调用。
第3部分:最终解决方案
很简单,在你的UIViewController中重写该方法,添加以下代码即可。
- (UIRectEdge)preferredScreenEdgesDeferringSystemGestures {
return UIRectEdgeBottom;
}
- 1
- 2
- 3
第4部分:总结
感觉这应该是苹果在开发时忽略的一个bug,虽然最终要解决它不是很复杂,但是找到解决方案还是耗费了不少时间,这样的问题还真的是挺坑的,在此记录一下。