iOS开发实践iOS精选博文iOS超神之路

【8行代码教你搞定导航控制器全屏滑动返回效果】 |那些人追的干货

2015-08-01  本文已影响14880人  袁峥

前言

此次文章,讲述的是导航控制器全屏滑动返回效果,而且代码量非常少,10行内搞定。
效果如图:


效果.gif

一、自定义导航控制器

目的:以后需要使用全屏滑动返回功能,就使用自己定义的导航控制器。

二、分析导航控制器侧滑功能

效果:导航控制器默认自带了侧滑功能,当用户在界面的左边滑动的时候,就会有侧滑功能。

系统自带的侧滑效果:

侧滑.gif

分析:
1.导航控制器的view自带了滑动手势,只不过手势的触发范围只能在左边。

2.当用户在界面左边拖动,就会触发滑动手势方法,并且有滑动返回功能,说明系统手势触发的方法已经实现了滑动返回功能。

3.为什么说系统手势触发的方法已经实现了滑动返回功能?

原因:

UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:target action:action];

三、实现全屏滑动功能分析

//  self指向的导航控制器,在导航控制器的viewDidLoad方法打印
- (void)viewDidLoad {
    [super viewDidLoad];
    NSLog(@"%@",self.interactivePopGestureRecognizer);
}

打印结果图片:

Snip20150801_1.png

分析:

四、如何实现全屏滑动功能

    // 打印系统自带滑动手势的代理对象
    NSLog(@"%@",self.interactivePopGestureRecognizer.delegate);


Snip20150801_2.png
- (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;
}

联系方式

如果你喜欢这篇文章,可以继续关注我,微博:吖了个峥,欢迎交流。

上一篇 下一篇

猜你喜欢

热点阅读