zoukankan      html  css  js  c++  java
  • UINavigationController使用的一些技巧

    1,创建并使用一个UINavigationController

    UINavigationController
    *aNav = [[UINavigationController alloc] init];
    然后添加一个视图进去,否则导航栏也没有意义的

    UIViewController
    *aView = [[UIView alloc] initWithNibName: (*xib文件名*)];[aNav pushViewController:aView animated:NO];//导航栏的第一个视图不要动画化
    2,设置导航栏的左右按钮:
    我说过,设置导航栏的按钮并不是去设置导航栏本身,而是当时被导航的视图控制器,比如我们对aView作设置。

    设置其标题:

    aView.title
    = @"标题"; //配置一个按钮,我这里是《我的佛典》上的代码UIBarButtonItem *callModalViewButton = [[UIBarButtonItem alloc] initWithTitle:@"经文" style:UIBarButtonItemStyleBordered target:self action:@selector(callModalList)];self.navigationItem.leftBarButtonItem = callModalViewButton;[callModalViewButton release]; //由于本地视图会retain它,所以我们可以release了
    可以看到,还是很简单的嘛。

    3,其他常用方法和属性:

    本地视图.navigationItem.leftBarButtonItem
    //左边栏项目本地视图.navigationItem.rightBarButtonItem //右边栏项目本地视图.navigationItem.backBarButtonItem //后退栏项目本地视图.navigationItem.hidesBackButton //隐藏后退按钮(YES or NO)
    在视图的viewWillAppear:方法中添加:


    [self.tableView reloadData];

    不起作用,viewWillAppear:这个方法根本没有调用

    后来发现原来用了UINavigationController后,viewWillAppear方法是没有效果的,要用UINavigationControllerDelegate的– navigationController:willShowViewController:animated:方法才可以达到这个目的。

    所以要做到这个,你必须做以下几步:

    1. 设置代理类


    nav.
    delegate = self;

    2. 代理类实现UINavigationControllerDelegate Protocol
    3. 在代理类中添加– navigationController:willShowViewController:animated:方法

    如:






    - (void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated {
    [self.myTableView reloadData];
    }

    pushViewController:viewController animated:BOOL

    (加载视图控制器)
    – 添加指定的视图控制器并予以显示,后接:是否动画显示

    popViewControllerAnimated:BOOL

    (弹出当前视图控制器)
    – 弹出并向左显示前一个视图

    popToViewController:viewController animated:BOOL

    (弹出到指定视图控制器)
    – 回到指定视图控制器, 也就是不只弹出一个

    popToRootViewControllerAnimated:BOOL

    (弹出到根视图控制器)
    – 比如说你有一个“Home”键,也许就会实施这个方法了。

    setNavigationBarHidden:BOOL animated:BOOL

    (设置导航栏是否显示)
    – 如果你想隐藏导航栏,这就是地方了。参照Picasa的WebApp样式


    现pushViewController:animated:的不同页面转换特效



    1. 首先要明确的是,不使用pushViewController的默认动画,所以在调用这个函数时,要将animated设置为NO.

    2. 使用普通的来CATransition实现转换效果,代码如下:

    CATransition
    *animation = [CATransition animation];

    [animation setDuration:
    0.3];

    [animation setType: kCATransitionMoveIn];

    [animation setSubtype: kCATransitionFromTop];

    [animation setTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionDefault]];



    [self.navigationController pushViewController:m_poseAddIssueViewController animated:NO];



    [self.navigationController.view.layer addAnimation:animation forKey:nil];

  • 相关阅读:
    springboot中多端口启动(这里也适用于https既443端口)
    Gson的fromJson()方法(从Json相关对象到Java实体或转换成List集合)
    [C++] STL源码中学到的 Traits 编程技法的应用
    【解决问题】UNIAPP、VUE 中DATA 数组更新后页面不同步动态渲染更新
    selenium操作chrome时的一些配置
    在react项目中使用fetch 和 JWT进行权限验证(转)
    滚动条的设置(样式包括宽度,颜色等)zhuan
    css3 box-shadow阴影(外阴影与外发光)图示讲解(zhuan)
    js 截断字符串 超过几个字加...
    create-react-app 打包部署
  • 原文地址:https://www.cnblogs.com/pipizhu/p/2063235.html
Copyright © 2011-2022 走看看