[TwistedFate]导航视图控制器

原创 2015年11月19日 19:37:01

导航视图控制器UINavigationController

导航控制器,是iOS中最常⽤的多视图控制器之⼀,它⽤来管理多个视图控制器。
导航控制器可以认为是管理控制器的控制器,主要管理有层级关系的控制器
UINavigationController通过栈的⽅式管理控制器的切换,控制⼊栈和出栈来展⽰各个视图控制器
UINavigationController的ContentView⾥始终显⽰栈顶控制器的view。

初始化并设为根视图控制器

RootViewController *rootVC = [[RootViewController alloc] init];
// 初始化时 需要一个根视图控制器 去管理(去显示)
UINavigationController *naVC = [[UINavigationController alloc] initWithRootViewController:rootVC];
// 只要是UIViewController子类都可以设置为window的根视图控制器
self.window.rootViewController = naVC;
[rootVC release];
[naVC release];

取出管理的数组

NSArray *array = self.navigationController.viewControllers;

界面跳转

跳到下一级界面

SecondViewController *secondVC = [[SecondViewController alloc] init];
    // 控制器中有一个导航控制器的属性
    // 一旦这个视图控制器被导航控制个管理了
    // 那么视图控制器中的  导航控制器属性 就会有值
    // 那么这个值 就是管理他的那个导航控制器
    [self.navigationController pushViewController:secondVC animated:YES];
    [secondVC release];

返回上一级控制器

[self.navigationController popViewControllerAnimated:YES];

导航条UINavigationBar

  • 导航条 44
  • 状态栏 20
  • 导航条的高度就是44 状态的背景 是导航条延伸过去的

设置导航条的背景颜色

self.navigationController.navigationBar.barTintColor = [UIColor cyanColor];

设置背景图片

  • 横屏状态下 导航条高32
  • 1.图片高度 < 44 效果:平铺
  • 2.图片高度 = 44 效果:只覆盖导航条
  • 3.图片高度 大于 44 小于 64 效果:平铺
  • 4.图片高度 = 64 效果:正好覆盖导航条与状态栏
[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"32064"] forBarMetrics:(UIBarMetricsDefault)];

关闭半透明

// iOS 7.0之后 导航条默认时半透明的
// 起始点是屏幕的左上角 开始计算
// 关闭半透明 后 起始点从导航条下面  开始计算
self.navigationController.navigationBar.translucent = NO;
// 一般咱们使用默认的半透明状态 不用考虑起始点的

导航栏按钮UIBarButtonItem

三种方式初始化左右按钮

// 标题初始化 左按钮
//    UIBarButtonItem *barButton = [[UIBarButtonItem alloc] initWithTitle:@"左按钮" style:(UIBarButtonItemStylePlain) target:self action:@selector(barButtonClick:)];
//    设置左按钮  当前页面上的  按钮
//    self.navigationItem.leftBarButtonItem = barButton;
//    [barButton release];

// 用图片初始化 右边的按钮
    UIBarButtonItem *rightBarButton = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"right"] style:(UIBarButtonItemStylePlain) target:self action:@selector(barButtonRight:)];
    self.navigationItem.rightBarButtonItem = rightBarButton;
    [rightBarButton release];

// 用系统的样式初始化左边的按钮
UIBarButtonItem *sysetemBarButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:(UIBarButtonSystemItemSave) target:self action:@selector(barButtonClick:)];
self.navigationItem.leftBarButtonItem = sysetemBarButton;
 [sysetemBarButton release];

设置页面的导航栏标题

self.navigationItem.title = @"首页";

在标题位置设置一个视图(位置不能更改 居中显示)

 self.navigationItem.titleView = [[UIView alloc] initWithFrame:CGRectMake(100, 100, 150, 44)];
    self.navigationItem.titleView.backgroundColor = [UIColor cyanColor];

    [self.navigationItem.titleView release];

相关文章推荐

视图控制器与导航模式-源码ppt

  • 2016年08月26日 11:17
  • 4.02MB
  • 下载

导航视图控制器(总结)

导航视图控制器 : UINavigationController 继承于 UIViewController注意:导航控制器高度是44,上面的状态栏高度是20,加在一起默认是64效果图: 1.创建...

iOS中的UINavigationController导航栏视图控制器的简单应用

在这篇文章中简单的总结了一些UINavigationController导航栏视图控制器的简单用法 1.首先使用这个导航栏控制器,需要将另外一个控制器设置为这个导航栏控制器的根视图控制器...

UI_导航视图控制器

UI_导航视图控制器

UI07_导航视图控制器-从后往前传值

以协议的方式进行从后往前传值1.声明一份协议@protocol SecondViewControllerDelegate //协议方法main更需要用参数,谁用返回值.需要什么就要设置什么 要做的事情...

问题:分页导航--子视图控制器自定义实现

想自定义子视图控制器来实现分页导航,出了一点点问题咯,先附上代码 (1)...

Objective--C 导航视图控制器

导航视图器相当于视图器的一个总管理者,在根视图创建后,任何一个视图控制器都能使用 一:创建 // 创建视图控制器 RootViewController *rootVC = [[Root...

UI12-导航栏视图控制器的使用

新建工程,创建三个类继承自UIViewController,分别是FirstViewController、SecondViewController 、ThirdViewController 一、编写A...

xcode6如何新建一个空项目+添加导航视图控制器

欢迎转载,请注明出处。 解说:使用xcode6的Empty项目模板创建出的项目啥都没有,及不方便。本编就先教大家如何创建一个包含有Target以及Appdelegate等目录的空项目以及添加导航...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[TwistedFate]导航视图控制器
举报原因:
原因补充:

(最多只允许输入30个字)