iOS左滑手勢失效的解決方法
iOS7之后,蘋果優(yōu)化了一個小功能,就是對于UINavagationController堆棧里的UIViewController,只要輕輕在視圖控制器的左邊緣右滑一下,該視圖控制器就會pop出棧(前提當然是對于非根視圖控制器而言)。實現(xiàn)方法很簡單,一句話搞定:
self.navigationController.interactivePopGestureRecognizer.enabled = YES;
事實上對于一個視圖控制器而言,該屬性的默認值即為YES,因此不設(shè)置也能實現(xiàn)右滑pop的功能。
然而這個功能很有局限性,因為它不允許當前視圖控制器自定義了leftBarButtonItem,一旦自定義,右滑功能就會失效。這里有一個方法:
self.navigationController.interactivePopGestureRecognizer.delegate = nil;
設(shè)置代理為nil之后即便自定義了leftBarButtonItem也可以右滑pop。
或者,把手勢的許可打開 也可:
self.navigationController.interactivePopGestureRecognizer.enabled = YES ;
事實上如果自定義了leftBarButtonItem,常用的做法是重新設(shè)置代理:
- (void)viewDidAppear:(BOOL)animated{ self.navigationController.interactivePopGestureRecognizer.delegate = (id)self; }
然后實現(xiàn)手勢協(xié)議即可:
#pragma mark - UIGestureRecognizerDelegate - (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer*)gestureRecognizer{ //判斷是否為rootViewController if (self.navigationController && self.navigationController.viewControllers.count == 1) { return NO; } return YES; }
不過呢,如果我們自定義的返回button只是文字或圖片的話,這樣設(shè)置就可以,不會失效
UIBarButtonItem *item = [[UIBarButtonItem alloc]init]; item.title = @""; self.navigationItem.backBarButtonItem = item;
如果是要自定義view的當作button的話,就要用leftBarButtonItem設(shè)置,并用上述講的防止手勢失效的方案.
有朋友提出以上方式在多次滑動之后會導致界面假死,這里再給出一種解決方案:
在所有除一級頁面之外的頁面的viewDidAppear和viewWillDisappear中加入以下代碼:
- (void)viewWillDisappear:(BOOL)animated { [super viewWillDisappear:animated]; //代理置空,否則會閃退 if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { self.navigationController.interactivePopGestureRecognizer.delegate = nil; } } - (void)viewDidAppear:(BOOL)animated { [super viewDidAppear:animated]; //開啟iOS7的滑動返回效果 if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { //只有在二級頁面生效 if ([self.navigationController.viewControllers count] == 2) { self.navigationController.interactivePopGestureRecognizer.delegate = self; } } }
在UINavigationController的delegate中實現(xiàn)以下方法:
- (void)navigationController:(UINavigationController *)navigationController didShowViewController:(UIViewController *)viewController animated:(BOOL)animated { //開啟滑動手勢 if ([navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) { navigationController.interactivePopGestureRecognizer.enabled = YES; } }
在pushviewcontroller之前加入以下代碼:
//在切換界面的過程中禁止滑動手勢,避免界面卡死 if ([_currentNav respondsToSelector:@selector(interactivePopGestureRecognizer)]) { _currentNav.interactivePopGestureRecognizer.enabled = NO; } [_currentNav pushViewController:viewController animated:YES];
即可在實現(xiàn)滑動返回的同時,避免界面卡死的問題。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Apple?Watch?App?Lifecycle應用開發(fā)
這篇文章主要為大家介紹了Apple?Watch?App?Lifecycle應用開發(fā)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10iOS應用開發(fā)中實現(xiàn)頁面跳轉(zhuǎn)的簡單方法筆記
這篇文章主要介紹了iOS應用開發(fā)中實現(xiàn)頁面跳轉(zhuǎn)的簡單方法筆記,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-02-02iOS端React Native差異化增量更新的實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于iOS端React Native差異化增量更新的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-06-06iOS如何實現(xiàn)強制轉(zhuǎn)屏、強制橫屏和強制豎屏的實例代碼
本篇文章主要介紹了iOS如何實現(xiàn)強制轉(zhuǎn)屏、強制橫屏和強制豎屏的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07