项目中可能某些页面返回按钮需要自定义,然后在点击返回按钮时做出某些判断,或者直接pop到根控制器,这时候需要禁用侧滑返回手势,防止它不走判断的代码直接返回上个界面。
网上找了些资料,大致方法有两种,但要注意的点没有提到,容易出错,这里整理下:
需求:A -> B -> C,要求B页面禁用侧滑返回
1. B push到 C,C页面可以侧滑返回;
2. B pop回 A,再从A push D,D要可以侧滑返回。
方法一:
在B页面的生命周期设置如下代码
-(void)viewDidAppear:(BOOL)animated { [super viewDidAppear:animated]; if([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { self.navigationController.interactivePopGestureRecognizer.enabled = NO; } } -(void)viewWillDisappear:(BOOL)animated { [super viewWillDisappear:animated]; if([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { self.navigationController.interactivePopGestureRecognizer.enabled = YES; }; }
注意:
1、是在viewDidAppear里面禁用导航的侧滑手势,不要在viewWillAppear中设置!
如果在viewWillAppear中禁用了手势,你会发现B->C之后,在C界面侧滑返回时,APP会进入假死状态。原因是B界面将要出现时,你禁用了侧滑手势,导致C侧滑失败,界面卡住。所以要在B界面出现之后,再禁用侧滑手势。
2、要在viewWillDisappear里面激活导航的侧滑手势,不是viewDidDisappear!
导航是共用的,如果不激活就返回了,其他页面也将无法侧滑返回!而在viewDidDisappear设置激活是无效的,要在页面即将消失时激活。
方法二:
也是在B页面的生命周期设置如下代码。方法一是直接关闭和激活侧滑手势,方法二则是B遵循协议UIGestureRecognizerDelegate,设置侧滑交互代理,重写手势方法。
@property (weak, nonatomic) id<UIGestureRecognizerDelegate> restoreInteractivePopGestureDelegate; - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. _restoreInteractivePopGestureDelegate = self.navigationController.interactivePopGestureRecognizer.delegate; } -(void)viewDidAppear:(BOOL)animated { [super viewDidAppear:animated]; if([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { self.navigationController.interactivePopGestureRecognizer.delegate = self; } } -(void)viewWillDisappear:(BOOL)animated { [super viewWillDisappear:animated]; if([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { self.navigationController.interactivePopGestureRecognizer.delegate = _restoreInteractivePopGestureDelegate; }; } #pragma mark -UIGestureRecognizerDelegate -(BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer { return NO; }
这里主要解释下为什么要记录导航的侧滑手势代理:
我们有时候会自定义UINavigationController基类,里面可能已经设置了侧滑手势代理,所以在B界面出现后我们重新设置代理为B,消失前我们要把代理重新改回为原来的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍iOS禁用右滑返回的两种方法,包括了iOS禁用右滑返回的两种方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了iOS禁用右滑返回的具体代码,供大家参考,具体内容如下 方式一: 前提:如果使用的自定义UINavigationController基类,请不要在此基类里写相关的手势操作方法。 代码如下: 方式二: 流程:先设置代理---->重写手势操作方法 以上就是本文的全
本文向大家介绍iOS push侧滑返回功能实现方法,包括了iOS push侧滑返回功能实现方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了iOS push侧滑返回功能的具体代码,供大家参考,具体内容如下 开启iOS自带的push的侧滑返回功能(只有左侧边缘地带响应侧滑返回,并不是全局响应): 为防止导航控制器在根视图时触发手势 这样 在根视图侧滑返回操作,然后出发push会没有效
问题内容: 在这里四处寻找了一段时间,但似乎找不到有效的解决方案。 我试图在Swift中禁用滑动以返回到上一个视图手势。 我尝试了多种解决方案,包括: 和 是否有执行此操作的新方法或其他可行的方法? 问题答案: 您可以禁用它,但是不建议这样做,因为大多数iOS用户通过滑动来回退,而通过按后退按钮可以减少回退。如果要禁用它,则使用a 代替推送转移(不是很大的转移)更为合理。如果您真的想摆脱滑动返回功
本文向大家介绍IOS开发中禁止NavigationController的向右滑动返回,包括了IOS开发中禁止NavigationController的向右滑动返回的使用技巧和注意事项,需要的朋友参考一下 IOS开发中禁止NavigationController的向右滑动返回 大家在进行开法的时候细心的朋友会发现,。用后在屏幕的最左边,向右滑动,,你会发现,你的App返回到了上一个页面,这是怎么回事
本文向大家介绍Android GestureDetector手势滑动使用实例讲解,包括了Android GestureDetector手势滑动使用实例讲解的使用技巧和注意事项,需要的朋友参考一下 Gesture在 ViewGroup中使用 GestureDetector类可以让我们快速的处理手势事件,如点击,滑动等。 使用GestureDetector分三步: 1. 定义GestureDetect
TLDR:我需要一种方法以编程方式禁用Android 10手势导航,这样他们从侧面滑动时不会意外返回 背景:Android 10引入了手势导航,而不是底部的按钮。因此,现在在Android 10设备上启用了它,他们可以从屏幕的任一侧滑动返回,从底部滑动导航回家或在应用程序之间。然而,我正在AR中开发一个实现,希望将屏幕锁定为纵向,但允许用户浏览横向。 如果用户将手机切换到横向,但活动锁定为纵向,则