自定义导航栏的按钮,文字

转载 2016年08月29日 21:01:51

iOS开发之如何自定义导航栏的按钮,文字和背景图片 

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

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

方法一:

[objc] view plaincopy

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

[self.navigationController.navigationBar setBarTintColor:[UIColor colorWithRed:20/255.0 green:155/255.0 blue:213/255.0 alpha:1.0]];

[self.navigationController.navigationBar setTitleTextAttributes:[NSDictionary dictionaryWithObjectsAndKeys:[UIColor whiteColor],UITextAttributeTextColor,nil]];

效果如下:

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

方法二:

[objc] view plaincopy

//设置NavigationBar背景颜色

[[UINavigationBar appearance] setBarTintColor:[UIColor redColor]];

//@{}代表Dictionary

[[UINavigationBar appearance] setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor whiteColor]}];

在导航栏使用背景图片:

如果您的应用程序使用了自定义图像作为栏的背景,你需要提供一个“更大”的图片,使其延伸了状态栏的后面。导航栏的高度现在是从44点(88像素)更改为64点(128像素)。

仍然可以使用了setBackgroundImage:方法来指定自定义图像的导航栏。下面是代码行设置背景图片:

[objc] view plaincopy

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

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

改变导航栏标题的字体

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

UITextAttributeFont - 字体

UITextAttributeTextColor - 文字颜色

UITextAttributeTextShadowColor - 文字阴影颜色

UITextAttributeTextShadowOffset - 偏移用于文本阴影

[objc] view plaincopy

NSShadow *shadow = [[NSShadow alloc] init];

shadow.shadowColor = [UIColor colorWithRed:0.0 green:0.0 blue:0.0 alpha:0.8];

shadow.shadowOffset = CGSizeMake(0, 1);

[[UINavigationBar appearance] setTitleTextAttributes: [NSDictionary dictionaryWithObjectsAndKeys:

[UIColor colorWithRed:245.0/255.0 green:245.0/255.0 blue:245.0/255.0 alpha:1.0], NSForegroundColorAttributeName,

shadow, NSShadowAttributeName,

[UIFont fontWithName:@"HelveticaNeue-CondensedBlack" size:21.0], NSFontAttributeName, nil nil]];

使用图片作为导航栏标题

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

[objc] view plaincopy

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

添加多个栏按钮项目

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

[objc] view plaincopy

UIBarButtonItem *shareItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAction target:self action: nil nil];

UIBarButtonItem *cameraItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCamera target:self action: nil nil];

NSArray *itemsArr = @[shareItem,cameraItem];

self.navigationItem.rightBarButtonItems = itemsArr;

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

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

左侧显示了父页面的title:用户登录,可是我们想修改成返回,方式有很多,举些例子

方法一:

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

[objc] view plaincopy

UIBarButtonItem *item = [[UIBarButtonItem alloc] initWithTitle:@"返回" style:UIBarButtonItemStylePlain target:nil action:nil];

self.navigationItem.backBarButtonItem = item;

效果如下:

所有的子界面返回时都变成了我们定义的文字,如果不想显示文字,直接"",就会单独显示一个系统的返回箭头图标,也是很清晰的感觉。

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

[objc] view plaincopy

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

效果如下:

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

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

[objc] view plaincopy

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

self.title=[NSString stringWithFormat:@"第%lu页",(unsigned long)self.navigationController.viewControllers.count];

//自定义返回按钮

UIImage *backButtonImage = [[UIImage imageNamed:@"fanhui.png"] resizableImageWithCapInsets:UIEdgeInsetsMake(0, 30, 0, 0)];

[[UIBarButtonItem appearance] setBackButtonBackgroundImage:backButtonImage forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];

//将返回按钮的文字position设置不在屏幕上显示

[[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(NSIntegerMin, NSIntegerMin) forBarMetrics:UIBarMetricsDefault];

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

1、如果B视图有一个自定义的左侧按钮(leftBarButtonItem),则会显示这个自定义按钮;

2、如果B没有自定义按钮,但是A视图的backBarButtonItem属性有自定义项,则显示这个自定义项;

3、如果前2条都没有,则默认显示一个后退按钮,后退按钮的标题是A视图的标题

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!

¥ 打赏支持 

iOS 修改导航栏按钮的位置

UINavigationItem可以理解为Navigation Bar中的内容,通过编辑UINavigationItem,我们可以使得在Navigation Bar中显示想要的东西,比如设置标题、添加...
  • mofengluo
  • mofengluo
  • 2017年07月13日 12:01
  • 306

导航右边按钮按钮(图片/文字)

文字按钮 #pragma mark 创建收款纪录按钮(导航右边) /** * 创建收款纪录按钮(导航右边) */ -(void)createPaymentRecord{ UIButton...
  • jianandjan
  • jianandjan
  • 2015年11月13日 09:45
  • 718

自定义导航栏按钮UIBarButtonItem 文字或图片(定制)

IOS 定制中间突出UItabBar前言:公司的项目需要定制一个中间突出的TabBar,在github 上找到一份可以参考的代码(虽然是四年前的,但是还是很有参考价值)。 网址:https://git...
  • ws1352864983
  • ws1352864983
  • 2016年03月07日 18:39
  • 924

自定义导航栏按钮 标题

自定义导航栏按钮:     1.自定义按钮(创建一个按钮) 2.自定义导航栏标题颜色     2.自定义按钮图片(仅仅修改按钮背景图片)    3.修改右侧按钮同上,设置se...
  • qq_27364431
  • qq_27364431
  • 2015年07月10日 10:18
  • 820

自定义导航栏按钮

// 创建导航条自定义按钮 #define CUSTOMVIEW(VIEW) [[UIBarButtonItem alloc] initWithCustomView:VIEW]   U...
  • u013097325
  • u013097325
  • 2015年04月13日 14:38
  • 88

自定义导航栏按钮UIBarButtonItem 文字或图片

在4.0里定义导航条按钮通常是生成普通按钮,再用它生成导航条专用按钮。 [java] view plaincopy UIButton *bu...
  • quanqinayng
  • quanqinayng
  • 2014年03月21日 08:16
  • 980

自定义导航栏的左右按钮

第一种: UIImage *searchimage=[UIImage imageNamed:@"search.png"]; UIBarButtonItem *barbtn=[[UIBarB...
  • qq_32069425
  • qq_32069425
  • 2015年10月22日 21:30
  • 122

Xcode9学习笔记20 - 导航栏样式UINavigationController

self.navigationItem.prompt = "Loading..."//设置顶部导航区的提示文字 self.navigationController?.navigatio...
  • u011728344
  • u011728344
  • 2017年10月31日 07:07
  • 252

iOS,导航条自定义返回按钮后失去侧滑功能完美解决方案

在平时做项目时,有时候需要自定义导航条的返回按钮,这个时候会发现失去了系统自带的手势侧滑返回功能,网上很多解决方法效果是实现了,但是有卡顿现象。 下面的代码将完美解决这个问题: /** * 是...
  • qq_27325349
  • qq_27325349
  • 2015年12月30日 16:09
  • 1466

设置导航栏按钮 左偏

采用customView,添加自己定义的UIButton ... // 返回按钮内容左靠 button.contentHorizontalAlignment = UIControlC...
  • x1198928367
  • x1198928367
  • 2016年08月24日 17:03
  • 171
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:自定义导航栏的按钮,文字
举报原因:
原因补充:

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