iOS左滑手勢失效的解決方法
iOS7之后,蘋果優(yōu)化了一個小功能,就是對于UINavagationController堆棧里的UIViewController,只要輕輕在視圖控制器的左邊緣右滑一下,該視圖控制器就會pop出棧(前提當(dāng)然是對于非根視圖控制器而言)。實現(xiàn)方法很簡單,一句話搞定:
self.navigationController.interactivePopGestureRecognizer.enabled = YES;
事實上對于一個視圖控制器而言,該屬性的默認(rèn)值即為YES,因此不設(shè)置也能實現(xiàn)右滑pop的功能。
然而這個功能很有局限性,因為它不允許當(dāng)前視圖控制器自定義了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的當(dāng)作button的話,就要用leftBarButtonItem設(shè)置,并用上述講的防止手勢失效的方案.
有朋友提出以上方式在多次滑動之后會導(dǎo)致界面假死,這里再給出一種解決方案:
在所有除一級頁面之外的頁面的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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Apple?Watch?App?Lifecycle應(yīng)用開發(fā)
這篇文章主要為大家介紹了Apple?Watch?App?Lifecycle應(yīng)用開發(fā)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
iOS應(yīng)用開發(fā)中實現(xiàn)頁面跳轉(zhuǎn)的簡單方法筆記
這篇文章主要介紹了iOS應(yīng)用開發(fā)中實現(xiàn)頁面跳轉(zhuǎn)的簡單方法筆記,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-02-02
iOS端React Native差異化增量更新的實現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于iOS端React Native差異化增量更新的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06
iOS如何實現(xiàn)強制轉(zhuǎn)屏、強制橫屏和強制豎屏的實例代碼
本篇文章主要介紹了iOS如何實現(xiàn)強制轉(zhuǎn)屏、強制橫屏和強制豎屏的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07

