zoukankan      html  css  js  c++  java
  • ios 手势返回<1>

    极其简单取巧的方法

    iOS7之后是有侧滑返回手势功能的。注意,也就是说系统已经定义了一种手势,并且给这个手势已经添加了一个触发方法(重点)。但是,系统的这个手势的触发条件是必须从屏幕左边缘开始滑动。我们取巧的方法是自己写一个支持全屏滑动的手势,而其触发方法系统已经有,没必要自己实现pop的动画,所以直接就把系统的触发处理方法作为我们自己定义的手势的处理方法。

    #import "ViewController.h"
    
    @interface ViewController ()<UIGestureRecognizerDelegate>
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad
    {
        [super viewDidLoad];
    
        id target = self.navigationController.interactivePopGestureRecognizer.delegate;
    
        // handleNavigationTransition:为系统私有API,即系统自带侧滑手势的回调方法,我们在自己的手势上直接用它的回调方法
        UIPanGestureRecognizer *panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:target action:@selector(handleNavigationTransition:)];
        panGesture.delegate = self; // 设置手势代理,拦截手势触发
        [self.view addGestureRecognizer:panGesture];
    
        // 一定要禁止系统自带的滑动手势
        self.navigationController.interactivePopGestureRecognizer.enabled = NO;
    }
    
    
    // 什么时候调用,每次触发手势之前都会询问下代理方法,是否触发
    // 作用:拦截手势触发
    - (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer
    {
        // 当当前控制器是根控制器时,不可以侧滑返回,所以不能使其触发手势
        if(self.navigationController.childViewControllers.count == 1)
        {
            return NO;
        }
    
        return YES;
    }
    
    
    @end

    拓展

    方案二涉及到了自定义转场动画的东西。关于自定义转场动画有三个核心的协议:

    • UIViewControllerAnimatedTransitioning:遵从该协议的对象,即是我们自定义的动画;
    • UIViewControllerInteractiveTransitioning:遵从该协议实现动画可交互性。不过一般我们直接使用系统UIPercentDrivenInteractiveTransition类,不需自定义。
    • UIViewControllerContextTransitioning:遵从该协议,定义了转场时需要的元数据。一般不需自己定义。
  • 相关阅读:
    MyEclipse中配置Hibernate
    struts2_对Map进行双层迭代
    Hibernate关联关系全集
    CodeIgniter+Smarty配置
    去掉php框架CI默认url中的index.php【整理】
    jquery的show方法是display:block还是display:inline呢?
    Codeigniter中的Error【转】
    去除 inlineblock 空隙终极解决方案
    jquery三级折叠菜单
    css实现页面文字不换行、自动换行、强制换行
  • 原文地址:https://www.cnblogs.com/shenlaiyaoshi/p/8512923.html
Copyright © 2011-2022 走看看