iOS导航栏背景,标题和返回按钮文字颜色

在iOS7下,默认导航栏背景,颜色是这样的,接下来咱们就进行自定义,若是你仅仅是更改一下背景和颜色,代码会很简单,不须要很复杂的自定义View来替代leftBarItemios

 

更改导航栏的背景和文字Color

方法一:xcode

  //set NavigationBar 背景颜色&title 颜色  网络

  1. [self.navigationController.navigationBar setBarTintColor:[UIColor colorWithRed:20/255.0 green:155/255.0 blue:213/255.0 alpha:1.0]];  
  2. [self.navigationController.navigationBar setTitleTextAttributes:[NSDictionary dictionaryWithObjectsAndKeys:[UIColor whiteColor],UITextAttributeTextColor,nil]];  

效果以下:app

 

咱们把背景改为了蓝色,title文字改为了白色,是否是很简单呢?NavigationBar极其push过去的子页面也会是你修改后的背景颜色字体

方法二:ui

 
  1. //设置NavigationBar背景颜色  
  2. [[UINavigationBar appearance] setBarTintColor:[UIColor redColor]];  
  3. //@{}表明Dictionary  
  4. [[UINavigationBar appearance] setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor whiteColor]}];  

效果以下:spa

 



在导航栏使用背景图片:

若是您的应用程序使用了自定义图像做为栏的背景,你须要提供一个“更大”的图片,使其延伸了状态栏的后面。导航栏的高度如今是从44点(88像素)更改成64点(128像素)。
仍然可使用了setBackgroundImage:方法来指定自定义图像的导航栏。下面是代码行设置背景图片:.net

 
  1. [[UINavigationBar appearance] setBackgroundImage:[UIImage imageNamed:@"nav_bg.png"] forBarMetrics:UIBarMetricsDefault];  

效果图和上面的同样,我就不贴出来了。code

 

改变导航栏标题的字体

 

就像iOS 6,咱们能够经过使用导航栏的“titleTextAttributes”属性来自定义的文本样式。能够指定字体,文字颜色,文字阴影颜色,文字阴影在文本标题偏移属性字典,使用下面的文本属性键:orm

UITextAttributeFont - 字体
UITextAttributeTextColor - 文字颜色
UITextAttributeTextShadowColor - 文字阴影颜色
UITextAttributeTextShadowOffset - 偏移用于文本阴影

 
  1. NSShadow *shadow = [[NSShadow alloc] init];  
  2. shadow.shadowColor = [UIColor colorWithRed:0.0 green:0.0 blue:0.0 alpha:0.8];  
  3. shadow.shadowOffset = CGSizeMake(0, 1);  
  4. [[UINavigationBar appearance] setTitleTextAttributes: [NSDictionary dictionaryWithObjectsAndKeys:  
  5. [UIColor colorWithRed:245.0/255.0 green:245.0/255.0 blue:245.0/255.0 alpha:1.0], NSForegroundColorAttributeName,  
  6. shadow, NSShadowAttributeName,  
  7. [UIFont fontWithName:@"HelveticaNeue-CondensedBlack" size:21.0], NSFontAttributeName, nil nil]];  

 

使用图片做为导航栏标题

 

不想标题栏是光秃秃的文字?能够经过使用代码行中的图像或标志取代它:简单地改变titleview用来自定义,(适用于较低版本)

 
  1. self.navigationItem.titleView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"appcoda-logo.png"]];  

 

效果以下,我随便用了个图片,别介意:

 

添加多个栏按钮项目

您但愿添加导航栏的一侧不止一个栏按钮项目,不管是leftBarButtonItems和rightBarButtonItems 您在导航栏左侧/右侧指定自定义栏按钮项目。好比你想添加一个摄像头和一个共享按钮右侧的吧。您可使用下面的代码:

 
  1. UIBarButtonItem *shareItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAction target:self action: nil nil];  
  2. UIBarButtonItem *cameraItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCamera target:self action: nil nil];  
  3. NSArray *itemsArr = @[shareItem,cameraItem];  
  4. self.navigationItem.rightBarButtonItems = itemsArr;  

 

 

 

自定义后退按钮的文字和颜色

一般状况下,咱们使用UINavigationController时,push到的子页面,左上角会是系统自动取值上一层父页面的title名称,默认状况是这样,那么咱们该如何修改它呢?

左侧显示了父页面的title:用户登陆,但是咱们想修改为返回,方式有不少,举些例子

方法一:

经过设置navigationItem的backBarButtonItem能够直接更换文字,【注意,要在父视图的Controller中设置】以下:

 
  1. UIBarButtonItem *item = [[UIBarButtonItem alloc] initWithTitle:@"返回" style:UIBarButtonItemStylePlain target:nil action:nil];  
  2. self.navigationItem.backBarButtonItem = item;  

效果以下:

 

全部的子界面返回时都变成了咱们定义的文字,若是不想显示文字,直接"",就会单独显示一个系统的返回箭头图标,也是很清晰的感受。

 

作到这里发现文字颜色和背景有重复,那么如何自定义其颜色呢?在iOS7,能够改变tintColor属性,它提供了一个快速和简单的方式,下面是一个示例代码片断:

 
  1. [[UINavigationBar appearance] setTintColor:[UIColor whiteColor]];  

效果以下:

 

全是系统的图标和文字,这回看着舒服了,有木有?【除了后退按钮,请注意,tintColor属性影响全部按钮标题和按钮图像】

 

最后举个例子,另一种实现自定义导航控制器返回按钮,代码以下:

 
  1.  [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName: [UIColor redColor],NSFontAttributeName:[UIFont systemFontOfSize:19.0]}];  
  2.   
  3. self.title=[NSString stringWithFormat:@"第%lu页",(unsigned long)self.navigationController.viewControllers.count];  
  4.   
  5. //自定义返回按钮  
  6. UIImage *backButtonImage = [[UIImage imageNamed:@"fanhui.png"] resizableImageWithCapInsets:UIEdgeInsetsMake(0, 30, 0, 0)];  
  7. [[UIBarButtonItem appearance] setBackButtonBackgroundImage:backButtonImage forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];  
  8. //将返回按钮的文字position设置不在屏幕上显示  
  9. [[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(NSIntegerMin, NSIntegerMin) forBarMetrics:UIBarMetricsDefault];  


效果以下:

 

 

最后说一下使用pushViewController切换到下一个视图时,navigation controller按照如下3条顺序更改导航栏的左侧按钮(本段摘自网络):

一、若是B视图有一个自定义的左侧按钮(leftBarButtonItem),则会显示这个自定义按钮;二、若是B没有自定义按钮,可是A视图的backBarButtonItem属性有自定义项,则显示这个自定义项;三、若是前2条都没有,则默认显示一个后退按钮,后退按钮的标题是A视图的标题;

相关文章
相关标签/搜索