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

在导航栏使用背景图片:

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

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

[[UINavigationBarappearance]setBackgroundImage:[UIImageimageNamed:@"nav_bg.png"]forBarMetrics:UIBarMetricsDefault];

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

改变导航栏标题的字体

就像iOS

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

UITextAttributeFont - 字体

UITextAttributeTextColor- 文字颜色

UITextAttributeTextShadowColor - 文字阴影颜色

UITextAttributeTextShadowOffset - 偏移用于文本阴影

NSShadow*shadow = [[NSShadowalloc]init];

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

shadow.shadowOffset= CGSizeMake(0,1);

[[UINavigationBarappearance]setTitleTextAttributes: [NSDictionarydictionaryWithObjectsAndKeys:

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

shadow, NSShadowAttributeName,

[UIFontfontWithName:@"HelveticaNeue-CondensedBlack"size:21.0], NSFontAttributeName,nilnil]];

使用图片作为导航栏标题

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

self.navigationItem.titleView= [[UIImageViewalloc]initWithImage:[UIImageimageNamed:@"appcoda-logo.png"]];

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

a4c26d1e5885305701be709a3d33442f.png

添加多个栏按钮项目

您希望添加导航栏的一侧不止一个栏按钮项目,无论是leftBarButtonItems和rightBarButtonItems

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

UIBarButtonItem*shareItem = [[UIBarButtonItemalloc]initWithBarButtonSystemItem:UIBarButtonSystemItemActiontarget:selfaction:nilnil];

UIBarButtonItem*cameraItem = [[UIBarButtonItemalloc]initWithBarButtonSystemItem:UIBarButtonSystemItemCameratarget:selfaction:nilnil];

NSArray*itemsArr = @[shareItem,cameraItem];

self.navigationItem.rightBarButtonItems= itemsArr;

a4c26d1e5885305701be709a3d33442f.png

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

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

a4c26d1e5885305701be709a3d33442f.png

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

方法一:

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

UIBarButtonItem*item = [[UIBarButtonItemalloc]initWithTitle:@"返回"style:UIBarButtonItemStylePlaintarget:nilaction:nil];

self.navigationItem.backBarButtonItem= item;

效果如下:

a4c26d1e5885305701be709a3d33442f.png

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

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

[[UINavigationBarappearance]setTintColor:[UIColorwhiteColor]];

效果如下:

a4c26d1e5885305701be709a3d33442f.png

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

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

[self.navigationController.navigationBarsetTitleTextAttributes:@{NSForegroundColorAttributeName: [UIColorredColor],NSFontAttributeName:[UIFontsystemFontOfSize:19.0]}];

self.title=[NSStringstringWithFormat:@"第%lu页",(unsignedlong)self.navigationController.viewControllers.count];

//自定义返回按钮

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

[[UIBarButtonItemappearance]setBackButtonBackgroundImage:backButtonImageforState:UIControlStateNormalbarMetrics:UIBarMetricsDefault];

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

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

效果如下:

a4c26d1e5885305701be709a3d33442f.png

最后说一下使用pushViewController切换到下一个视图时,navigation

controller按照以下3条顺序更改导航栏的左侧按钮(本段摘自网络):

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

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

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

本文摘自:

http://blog.csdn.net/mad1989/article/details/41516743

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值