8行代码教你搞定导航控制器全屏滑动返回效果

http://www.cocoachina.com/ios/20150811/12897.html

作者:@吖了个峥授权本站转载

前言

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

效果如图:

如果喜欢我的文章,可以关注我,也可以来小码哥,了解下我们的iOS培训课程。陆续还会有更新ing....

一、自定义导航控制器

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

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

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

系统自带的侧滑效果:

分析:

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

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

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

原因:

  • 创建滑动手势对象的时候,需要绑定监听者,当触发手势的时候会调用target的action。

1

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

  • 当用户在界面左边滑动,有滑动返回功能,这是因为触发手势了,调用target的action方法,说明action方法内部实现滑动返回功能,否则就不会有滑动返回效果。

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

打印导航控制器自带的滑动手势,看下它的真实面目。

系统自带的滑动手势interactivePopGestureRecognizer


1

2

3

4

5

//  self指向的导航控制器,在导航控制器的viewDidLoad方法打印

- (void)viewDidLoad {

    [super viewDidLoad];

    NSLog(@"%@",self.interactivePopGestureRecognizer);

}

打印结果图片:

由图中可知:

1.系统自带的手势是UIScreenEdgePanGestureRecognizer类型对象,屏幕边缘滑动手势

2.系统自带手势target是_UINavigationInteractiveTransition类型的对象

3.target调用的action方法名叫handleNavigationTransition:

分析:

UIScreenEdgePanGestureRecognizer,看名称就知道,这个手势的范围只能在屏幕的周边,就是因为这个手势,系统自带的滑动效果,只能实现侧边滑动。

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

给自己的导航控制器,添加一个全屏的滑动手势,调用系统自带滑动手势的target的action方法,利用系统实现的滑动返回功能,加上自己全屏滑动手势,就有全屏滑动功能了。

问题:如何拿到系统自带的target对象?,action方法名已经知道,而且系统肯定在target对象实现了,只要拿到target对象,调用这个方法就行。

通过打印系统自带的滑动手势的代理,发现正好是_UINavigationInteractiveTransition对象,因此我猜测这个代理对象就是target对象,只要拿到它,就拿到系统自带滑动手势的target对象。


1

2

    // 打印系统自带滑动手势的代理对象

    NSLog(@"%@",self.interactivePopGestureRecognizer.delegate);

打印图片:

导航控制器全屏滑动注意点:

1.禁止系统自带滑动手势使用。

2.只有导航控制器的非根控制器才需要触发手势,使用手势代理,控制手势触发。

全屏滑动代码实现


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

- (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;

}

联系方式

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

(PS:另外咱们公司小码哥,诚邀IT届有事业心,有能力,有拼劲,有干劲各路英豪加盟一起创业,详情可以点击小码哥,小码哥官方微博,或者微博私聊我)

时间: 2024-10-16 05:18:52

8行代码教你搞定导航控制器全屏滑动返回效果的相关文章

iOS开发——实用技术OC篇&8行代码教你搞定导航控制器全屏滑动返回效果

8行代码教你搞定导航控制器全屏滑动返回效果 前言 此次文章,讲述的是导航控制器全屏滑动返回效果,而且代码量非常少,10行内搞定. 效果如图: 如果喜欢我的文章,可以关注我,也可以来小码哥,了解下我们的iOS培训课程.陆续还会有更新ing.... 一.自定义导航控制器 目的:以后需要使用全屏滑动返回功能,就使用自己定义的导航控制器. 二.分析导航控制器侧滑功能 效果:导航控制器默认自带了侧滑功能,当用户在界面的左边滑动的时候,就会有侧滑功能. 系统自带的侧滑效果: 分析: 1.导航控制器的view

ios 8行代码教你搞定导航控制器全屏滑动返回效果

一.自定义导航控制器 目的:以后需要使用全屏滑动返回功能,就使用自己定义的导航控制器. 二.分析导航控制器侧滑功能 效果:导航控制器默认自带了侧滑功能,当用户在界面的左边滑动的时候,就会有侧滑功能. 系统自带的侧滑效果: 分析: 1.导航控制器的view自带了滑动手势,只不过手势的触发范围只能在左边. 2.当用户在界面左边拖动,就会触发滑动手势方法,并且有滑动返回功能,说明系统手势触发的方法已经实现了滑动返回功能. 3.为什么说系统手势触发的方法已经实现了滑动返回功能? 原因: 创建滑动手势对象

iOS 中导航控制器全屏向右滑动返回上一界面

在iOS中,导航控制器默认就自带了侧滑功能,当用户在界面的左边(左边边缘)滑动的时候,才会有侧滑功能.但是我们往往在开发的过程中需要在屏幕的任意位置滑动,都需要返回到上一个界面. 多说无意,直接看代码: 效果图部分: 代码部分(第二个界面): #import "CJSecondViewController.h" @interface CJSecondViewController ()<UIGestureRecognizerDelegate> @end @implementa

自定义导航全屏滑动返回上一页

- (void)viewDidLoad { [super viewDidLoad]; // 获取系统自带滑动手势的target对象 id target = self.interactivePopGestureRecognizer.delegate; // 创建全屏滑动手势,调用系统自带滑动手势的target的action方法 UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:target ac

“你的这个只要一行代码就能搞定”

帮舍友代写了一个程序,中期检查的时候和他一起去见老师.老师看了说我们的工作量太少.这个几分钟就搞定.最后他居然说:"这个工作量太少了,就调用一行代码的事,几分钟就可以搞定".去之前我知道这个临时做出来的东西,肯定没跟上进度.但好歹有几天的工作量吧.他居然说只要几分钟,一行调用代码.难道用http协议从网上获取天气数据,再解析xml格式的数据,再转换字符串编码,再根据天气选择要绘制的图片和文字,只需要一行代码?难道我不需要查资料,不需要设计界面吗?为了用mfc做出这个界面,我确实费了一番

PDF怎么旋转,这个方法教你搞定

在工作的时候,当我们拿到文件的时候,会发现有很多都不是完整的,特别是当你拿到PDF文件的时候发现,PDF文件里面的内容是反的,需要旋转一下才能使用,这时候很多小伙伴们会很头疼,因为PDF文件本身就是很难进行编辑和修改的,那么PDF怎么旋转?下面就来告诉你吧,这个方法教你搞定.下面给大家介绍一款PDF转换器软件,能快速方便的旋转PDF文件中的一页或多页并保存成新的文档,简单.高效.一键操作,快速.方便.1.下面给大家分享的方法,就是使用软件来完成的,这个软件不仅可以旋转PDF文件,还可以进行PDF

ios 导航全屏滑动

全屏滑动代码实现 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 - (void)viewDidLoad {     [super viewDidLoad];     // 获取系统自带滑动手势的target对象     id target = self.interactivePopGestureRecognizer.delegate;     // 创建全屏滑动手势,调用系统自带滑动手势的target的acti

5行js代码搞定导航吸顶效果

一.HTML布局 首先写HTML布局 <body> <div id="wrap"></div> </body> 二.CSS样式 给点简单的样式 <style> *{ margin: 0; padding: 0; } body{ height: 2000px; background-image: linear-gradient(-180deg, #15f09d 0%, #25A0FF 50%, #fca72b 100%); }

iOS开发一行代码系列:一行搞定输入框

最近总结了下开发过程中常用的功能,发现有时候我在做重复性的劳动.于是决定把常用的功能抽出来,方便下次使用. 我的想法是:用最少的代码来解决问题.于是写了一些常用的工具类,名字就叫一行代码系列吧...好像挺挫的.. 大致内容有: 1.一行搞定输入框 2.一行搞定网络请求 3.一行搞定上下拉刷新(会自动判断是上拉还是下拉还是两者并存) 4.一行搞定数据库(最近还在写,功能已经基本实现) 5.一行搞定图片保存 6.一行搞定定位 7.一行搞定网络状况变化 8.一行搞定X(功能小集合) 一行搞定输入框 输