iOS侧滑返回实现

1. 使用官方API解决Navigation侧滑导致的Navigationbar异常显示和隐藏的问题

参考:http://blog.csdn.net/u012399891/article/details/50502035

问题一

登陆页面隐藏了navigationbar,注册和关于页面显示了navigationbar,在侧滑时如果从注册页面侧滑一半(不要松开手)让登陆页面显示然后再往左滑把登陆页面收起,此时点击关于页时头上的navigationbar就成了注册页的navigationbar。效果如下(附带正常效果):

问题二(原来的一个项目的效果就是问题二)

注册页侧滑回登陆页的过程中,注册页的navigationbar被隐藏了,而我们想要的效果是正常效果动画中的样子。

异常效果:


异常效果.gif

正常效果:


正常效果.gif

解决方法用forKingdog的开源框架中的一个分类就可以解决了:名称是UINavigationController+FDFullscreenPopGesture
(一个很不错的开源项目附地址:https://github.com/forkingdog)这个分类,然后在需要隐藏navigation bar的页面设置属性 self.fd_prefersNavigationBarHidden = YES;问题即可解决!

分类的分析:

现在给大家分享下成果,源码不多,一个.m文件也就200多行,代码,没有写特意写专场动画,使用系统的interactivePopGestureRecognizer.delegate也就是系统的转场动画来实现效果。那么说,系统就应该为我们实现好了我们想要的效果才对,于是乎继续查看搜索fd_prefersNavigationBarHidden到底是在什么地方调用,为何用了它切换时的动画效果就解决了。于是在下面的代码中找到了答案

- (void)fd_setupViewControllerBasedNavigationBarAppearanceIfNeeded:(UIViewController *)appearingViewController
{
    if (!self.fd_viewControllerBasedNavigationBarAppearanceEnabled) {
        return;
    }
    __weak typeof(self) weakSelf = self;
    _FDViewControllerWillAppearInjectBlock block = ^(UIViewController *viewController, BOOL animated) {
        __strong typeof(weakSelf) strongSelf = weakSelf;
        if (strongSelf) {
            [strongSelf setNavigationBarHidden:viewController.fd_prefersNavigationBarHidden animated:animated];
        }
    };

    appearingViewController.fd_willAppearInjectBlock = block;
    UIViewController *disappearingViewController = self.viewControllers.lastObject;
    if (disappearingViewController && !disappearingViewController.fd_willAppearInjectBlock) {
        disappearingViewController.fd_willAppearInjectBlock = block;
    }
}

重点:

[strongSelf setNavigationBarHidden:viewController.fd_prefersNavigationBarHiddenanimated:animated];

就是解决问题的关键,我们之前一直使用

self.navigationController.navigationBarHidden
或者self.navigationController.navigationBar.hidden来隐藏navigatiuonbar,
这样直接更改属性的方式是不带动画的,

而且滑动时的转场动画页不为我们处理好,才导致了问出的出现.

文章重点:

- (void)setNavigationBarHidden:(BOOL)hidden animated:(BOOL)animated;

为我们完美的解决这样的问题,作者不用UINavigationController+FDFullscreenPopGesture,而是使用系统默认的API来尝试解决:

给自定义navigation添加侧滑转场动画:

#import "MyNavigationController.h"
@interface MyNavigationController()<UIGestureRecognizerDelegate>

@end

@implementation MyNavigationController

- (void)viewDidLoad {
    [super viewDidLoad];

        // 获取系统自带滑动手势的target对象
        id target = self.interactivePopGestureRecognizer.delegate;

        // 创建全屏滑动手势,调用系统自带滑动手势的target的action方法
        UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:target action:@selector(handleNavigationTransition:)];

        // 设置手势代理,拦截手势触发
        pan.delegate = self;

        // 给导航控制器的view添加全屏滑动手势
        [self.view addGestureRecognizer:pan];

        // 禁止使用系统自带的滑动手势
        self.interactivePopGestureRecognizer.enabled = NO;
}

- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer
{
    // 注意:只有非根控制器才有滑动返回功能,根控制器没有。
    // 判断导航控制器是否只有一个子控制器,如果只有一个子控制器,肯定是根控制器
    if (self.childViewControllers.count == 1) {
        // 表示用户在根控制器界面,就不需要触发滑动手势,
        return NO;
    }
    return YES;
}

@end

然后再创建3个ViewController来相互切换,第一个是隐藏navigationbar的,后面2个不隐藏
隐藏navigationbar的ViewController代码如下:

-(void)viewWillAppear:(BOOL)animated{
    [super viewWillAppear:animated];

    [self.navigationController setNavigationBarHidden:YES animated:YES];
}

不隐藏navigationbar的ViewController代码如下:

-(void)viewWillAppear:(BOOL)animated{
    [super viewWillAppear:animated];
    [self.navigationController setNavigationBarHidden:NO animated:YES];
}

附上使用- (void)setNavigationBarHidden:(BOOL)hidden animated:(BOOL)animated的效果图:

动画.gif

附上使用navigationController.navigationBar.hidden的效果对比:

非动画.gif

demo项目地址:https://github.com/CharmingLee/FullscreenPopGesture.Git

这个demo有缺点:
从右边忘左边划动也能触发侧滑操作,有手势冲突,并不完美。且调用官方私有API

另外:正是缺点的所在,和Cell的侧滑删除手势也是有冲突的,也就是说,免不了需要解决手势的冲突。

适用需求:最好不用,毕竟缺点明显

2.关于UINavigationController+FDFullscreenPopGesture请参考

这个三方实现(集成最简单、功能最全面):
参考://blog.sunnyxx.com/2015/06/07/fullscreen-pop-gesture/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,089评论 4 62
  • 一直在想,自己能不能写一些像样的东西?但是真正拿起手机,才发现自己脑袋里实在空,根本写不出什么。 If I wan...
    两个逗儿阅读 74评论 0 0
  • 【八六子(仲春夜雨骤)】 钟瑞意 雾蒙蒙,昨宵窗外,长闻雨舞春风。一夜婆娑渐晓,眺望云压苍穹,远山黛峰。 ...
    粤东文苑阅读 489评论 2 0
  • 今天遇到的问题是DrawerLayout在上面,下面的View拿不到点击事件,最后实在没办法,都曲线救国了(只要解...
    BertSir阅读 1,001评论 0 0