zoukankan      html  css  js  c++  java
  • UIViewContrller之间切换的几种方式

    转自:http://blog.csdn.net/likendsl/article/details/7542296
     
    1.UIViewContrller之间的切换有三种方式:
        一、UIViewController自身之间的调用:[self presentModalViewController:UIViewController animated:YES];
    对应的返回操作函数:[self dismissModalViewControllerAnimated:YES];这里的self代表的是UIViewController自己。
       其可设置四种动画模式:
    case 0:
    [ctrl setModalTransitionStyle:UIModalTransitionStyleCoverVertical]; //底部向上 默认的动画方式
    break;
    case 1:
    [ctrl setModalTransitionStyle:UIModalTransitionStyleCrossDissolve]; //渐变
    break;
    case 2:
    [ctrl setModalTransitionStyle:UIModalTransitionStyleFlipHorizontal]; //翻转
    break;
    case 3:
    [ctrl setModalTransitionStyle:UIModalTransitionStylePartialCurl]; //翻半页
    break;
    default:
    [ctrl setModalTransitionStyle:UIModalTransitionStyleCoverVertical]; //底部向上 默认的动画方式
    break;
           二、通过UIViewController的子类UINavigationControlle导航控制器的Controller来控制ViewContrller之间的切换,这种切换模式适合于具有层次逻辑性的ViewContrller之间的切换。
    对应的调用函数:[self.navigationController pushViewController:ctrl animated:YES]; 
    返回:[self.navigationController popViewControllerAnimated:YES];,
    也可直接指定返回到那一个ViewController:
    - (NSArray *)popToViewController:(UIViewController *)viewController animated:(BOOL)animated
    还可以直接返回到RootViewController:- (NSArray *)popToRootViewControllerAnimated:(BOOL)animated
     
        实现NavigationController的delegate可以在返回时做相应的更新操作(- (void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated )
     
          三、就是UITabBarContrller其也是继承于UIViewController,主要是做具有并行逻辑特点的ViewController之间的切换。

    UITabBarContrller对象有一个属性selectedIndex,设置初始时默认展示的ViewController。

    而当点击tabBarItem时触发切换操作  都会回调UITabBarControllerDelegate中的一个方法

    - (void)tabBarController:(UITabBarController *)tabBarController didSelectViewController:(UIViewController *) viewController 

    Controller调用了返回函数,如dismiss,pop等等,那么就会被清理掉。
    备注:如果Controller或view中有线程或者定时器之类的动画操作如果没有结束那么这个Controller或view就会出现内存泄露了。
     
     
    参考2:http://www.haogongju.net/art/2590704

    视图切换,没有NavigationController的情况下,一般会使用presentViewController来切换视图并携带切换时的动画,

    其中切换方法如下:

    – presentViewController:animated:completion: 弹出,出现一个新视图 可以带动画效果,完成后可以做相应的执行函数经常为nil
    – dismissViewControllerAnimated:completion:退出一个新视图 可以带动画效果,完成后可以做相应的执行函数经常为nil

    切换动画在压入一个新视图和弹出顶层视图均可以使用,下面只以压入视图为例。


    presentModalViewController:animated:completion:使用系统自带四种动画

    简单的实现方式:

    [page2Controller setModalTransitionStyle:UIModalTransitionStyleFlipHorizontal]; [self presentModalViewController:myNextViewController animated:YES completion:nil];

    系统支持的四种动画:

    typedef enum { UIModalTransitionStyleCoverVertical=0, //默认方式,竖向上推 UIModalTransitionStyleFlipHorizontal, //水平反转 UIModalTransitionStyleCrossDissolve,//隐出隐现 UIModalTransitionStylePartialCurl,//部分翻页效果 } UIModalTransitionStyle;

    presentModalViewController:animated:completion: 不用自带的四种动画效果    

    实现全翻页效果:

    CATransition *animation = [CATransition animation]; animation.duration = 1.0; animation.timingFunction = UIViewAnimationCurveEaseInOut; animation.type = @"pageCurl"; //animation.type = kCATransitionPush; animation.subtype = kCATransitionFromLeft; [self.view.window.layer addAnimation:animation forKey:nil]; [self presentModalViewController:myNextViewController animated:NO completion:nil];

    常見的轉換類型(type):

    kCATransitionFade //淡出 kCATransitionMoveIn //覆盖原图 kCATransitionPush //推出 kCATransitionReveal //底部显出来

    SubType:

    kCATransitionFromRight kCATransitionFromLeft // 默认值  kCATransitionFromTop kCATransitionFromBottom

    设置其他动画类型的方法(type):

    pageCurl 向上翻一页 pageUnCurl 向下翻一页 rippleEffect 滴水效果 suckEffect 收缩效果,如一块布被抽走 cube 立方体效果 oglFlip 上下翻转效果
  • 相关阅读:
    (转)CentOS 6.5下Redis安装详细步骤
    (转)FastDFS_v5.05安装配置
    Mybatis 动态获取字段值(不需要创建javabean)
    Apache+tomcat集群配置
    Get Started and Make Progress in Machine Learning
    NLTK 模块不完全介绍
    python __future__
    python __init__.py和__all__
    自然语言处理
    Python搜索路径
  • 原文地址:https://www.cnblogs.com/wangpei/p/4067114.html
Copyright © 2011-2022 走看看