UINavigationController(二)

在使用UINavigtionController的时候,常常会弄不清哪些属性是UINavigationController的,哪些属性是UIViewController的。并且在更改导航栏和工具栏的样式的时候,常常会于遇到api使用下去没有效果的情况。总之,一直用得比較混乱,今天要好好做一个总结,把那些常常使用的功能都搞清楚。

一、怎样往导航栏和工具栏加入button

1、navigationItem属性

这个属性是UIViewController在UINavigationControllerItem类目下的。

@property(nonatomic,readonly,retain)UINavigationItem *navigationItem;

文档的解释:在必要的时候会创建该属性对象。以便于控制器能够定制它自己的导航栏外观。

UINavigationItem有下面属性:

@property(nonatomic,retain)UIBarButtonItem *leftBarButtonItem;//导航栏左边的button,位置与“返回”button同样

@property(nonatomic,retain)UIBarButtonItem *rightBarButtonItem;//导航栏右边的button

@property(nonatomic,retain)UIBarButtonItem *backBarButtonItem; //假设前面的那个控制器有title内容,则back button的内容为<title,假设没有title。默认显示<back

@property(nonatomic,retain)UIView *titleView;//自己定义title的样式

@property(nonatomic,copy)NSArray *leftBarButtonItems NS_AVAILABLE_IOS(5_0);//使用该属性,能在导航栏左边显示多个button

@property(nonatomic,copy)NSArray *rightBarButtonItems NS_AVAILABLE_IOS(5_0);//类似leftBarButtonItems属性

@property(nonatomic,copy)NSString *title;//给它赋值的效果相当于给控制器的title属性赋值一样

@property(nonatomic,copy)NSString *prompt; //文字内容会显示在title的上面。这个属性会使得导航栏的高度添加30

@property(nonatomic) BOOL leftItemsSupplementBackButton NS_AVAILABLE_IOS(5_0);//默认值为NO。在leftbutton和backbutton同一时候存在的情况下,仅仅显示leftbutton;假设设为YES,将会显示backbutton和leftbutton,backbutton显示在leftbutton前面

@property(nonatomic,assign)BOOL hidesBackButton;

2、toolbarItems属性

这个属性是UIViewController在UINavigationControllerContextualToolbarItems类目下的。

@property (nonatomic,retain)NSArray
*toolbarItemsNS_AVAILABLE_IOS(3_0);

功能:在UIViewController中创建一系列UIBarButtonItem对象。将这些对象加入到toolbarItems数组中,这些UIBarButtonItembutton就会显示在控制器底部的工具栏中。

代码例如以下:

UIBarButtonItem *refreshItem = [[UIBarButtonItem alloc]initWithCustomView:refreshButton];
    //每一个控制器有自己的toolbaritems属性,管理工具栏的数组
[self setToolbarItems:[NSArray arrayWithObjects:refreshItem, nil]];

二、怎样定制导航栏和工具栏的样式

1、导航栏的样式:

navigationBar是UINavigationController的属性

(1)导航栏左右两边的button

从ios7開始,tintColor属性仅仅能设置导航栏上button的字体颜色。无法影响到导航栏的背景色。

(2)导航栏中间的title

从ios5開始。titleTextAttributes属性能够设置title的字体、颜色、大小等。

比如:

[self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor redColor],NSFontAttributeName:[UIFont boldSystemFontOfSize:20]}];

NSForegroundColorAttributeName是keyword。表示文字的颜色

NSFontAttributeName表示字体大小和样式。

//这里的两个keyword是ios7開始才有的,ios7之前有另外的相应keyword

(3)导航栏的背景

颜色:从ios7開始。导航栏的背景色由barTintColor来设置,它会把状态栏也变成一样的颜色。

背景图:从ios5開始。

- (void)setBackgroundImage:(UIImage
*)backgroundImage forBarMetrics:(UIBarMetrics)barMetrics用于设置导航栏背景图片

(4)导航栏的显示与隐藏

仅仅有UINavigationController的navigationBarHidden属性才干控制导航栏的显示和隐藏。

2、工具栏的样式:

toolbar是UINavigationController的属性

(1)工具栏的button

与navigationbar一样的情况。从ios7開始。tintcolor属性设置button的字体颜色

(2)工具栏的背景色

bartintcolor设置工具栏的背景颜色

(3)工具栏的背景图片

- (void)setBackgroundImage:(UIImage *)backgroundImage forToolbarPosition:(UIBarPosition)topOrBottom barMetrics:(UIBarMetrics)barMetrics

(4)工具栏的显示和隐藏

仅仅有UINavigationController的toolbarHidden属性才干控制导航栏的显示和隐藏。

三、NavigationBar的显示困惑

1、leftbutton和backbutton

(1)假设当前控制器设置了leftbutton。优先显示leftbutton

(2)假设当前控制器没有设置leftbutton,且当前控制器不是导航控制器的根。则显示前面那个控制器的backbutton。假设前面那个控制器没有指定backbutton。则系统会依据前一层的控制器的title属性生成一个backbutton。假设前一层控制器的title为“pre”,则backbutton显示为“<pre”,否则显示为“<back”.

能够说。当前控制器的backbutton是为后面的那个控制器准备的。

(3)假设当前控制器没有leftbutton,且当前控制器是导航控制器的根。则导航栏左边没有不论什么显示。

2、控制器的title和navigationItem的title、titleView

(1)假设navigationItem的titleview属性有指定,优先显示titileview的样式

(2)假设titleview没有指定,优先显示navigationItem的title的文字

(3)假设navigationItem的title没有指定,就以控制器的title属性来显示。

四、导航控制器的栈

1、UINavigationController的viewControllers属性NSArray类型,存放当前在导航控制器栈内的全部视图控制器。

2、topViewController属性指的是导航控制器栈顶的视图控制器。

3、visibleViewController属性,假设栈顶的控制器还显示了一个模态视图控制器。则指向该模态视图控制器,否则就是栈顶的那个视图控制器。

时间: 2024-12-11 16:37:17

UINavigationController(二)的相关文章

UINavigationController 、界面通信

一.UINavigationController 二.定制UINavigationBar 三.界面间通信 一.UINavigationController 导航控制器,是iOS中最常用的多视图控制器之一,它用来管多个视图控制器.导航控制器可以认为是管理控制器的控制器,主要管理有层级关系的控制器. UINavigationController继承于UIViewController,以栈的方式管理所控制的视图控制器, 至少要有一个被管理的视图控制器,这个控制器我们称作,导航控制器的根视图控制器. 任

UINavigationController详解二(转)页面切换和SegmentedController

原文出自:http://blog.csdn.net/totogo2010/article/details/7682433,非常感谢. 1.RootView 跳到SecondView 首先我们需要新一个View.新建SecondView,按住Command键然后按N,弹出新建页面,我们新建SecondView 2.为Button 添加点击事件,实现跳转 在RootViewController.xib中和RootViewController.h文件建立连接 在RootViewController.m

iOS学习之UINavigationController详解与使用(二)页面切换和segmentedController

1.RootView 跳到SecondView 首先我们需要新一个View.新建SecondView,按住Command键然后按N,弹出新建页面,我们新建SecondView 2.为Button 添加点击事件,实现跳转 在RootViewController.xib中和RootViewController.h文件建立连接 在RootViewController.m中实现代码,alloc一个SecondViewController,用pushViewController到navigationCon

[转]iOS学习之UINavigationController详解与使用(二)页面切换和segmentedController

转载地址:http://blog.csdn.net/totogo2010/article/details/7682433 iOS学习之UINavigationController详解与使用(一)添加UIBarButtonItem是上篇,我们接着讲UINavigationController的重要作用,页面的管理和切换. 1.RootView 跳到SecondView 首先我们需要新一个View.新建SecondView,按住Command键然后按N,弹出新建页面,我们新建SecondView 2

IOS 基础之 (二十三) UINavigationController控制器

一 导航控制器 利用UINavigationController,可以轻松地管理多个控制器,轻松完成控制器之间的切换,典型例子就是系统自带的“设置”应用 AppDelegate.m - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { //创建window self.window = [[UIWindow alloc]init];

swift详解之二十二-----------UINavigationController的基本用法和页面传值几种方式

UINavigationController的基本用法和页面传值几种方式 本文介绍UINavigationController基本用法,因为涉及多页面顺便介绍页面传值 1.手写代码创建UINavigationController 手写方式创建很简单 , 首先创建一个项目 , 默认是从storyboard 加载的.这时候首先去掉默认加载方式 . 然后在AppDelegate.swift 的didFinishLaunchingWithOptions 中创建 代码如下: func applicatio

swift详解之二十七------------自定义UINavigationController的push和pop动画

自定义UINavigationController的push和pop动画 我们这里先创建一个简单的工程 , 在storyboard 中拖一个导航控制器 , rootViewController 改成我们的ViewController . 为了实现自定义动画切换 , 我们需要实现两个协议 . UIViewControllerAnimatedTransitioning,UINavigationControllerDelegate UIViewControllerAnimatedTransitioni

StoryBoard初探(二):使用UINavigationController和UITabBarController

UINavigationController StoryBoard的Segue类型有三种:Push,Modal,Custom.其中Push类型的Segue需要用到UINavigationController.第一步,先清空之前所有的连线和连接,选择ViewController,打开Editor菜单,选择Embed In选项中的Navigation Controller. 主窗口区域会出现一个UINavigationController实例 按照第一篇的方式,Ctrl连线ViewControlle

UINavigationController + UIScrollView组合,视图尺寸的设置探秘(二)

承接上文,我想把view布局修改为如下模式,让ScrollView长在NavigationBar的下方,这总不会有遮挡的问题了吧: story board内容如下,主要是右侧视图蓝色区域添加了ScrollView: ViewController的代码如下: @interface ViewController () @property (weak, nonatomic) IBOutlet UIScrollView *scrollView; @property (nonatomic, strong)