首页 > IOS频道 > 【IOS研究院之应用开发】 > IOS研究院之在IOS5中使用NavigationBar导航栏(八)
2012
07-24

IOS研究院之在IOS5中使用NavigationBar导航栏(八)

        系统自带的NavigationBar局限性比较大,往往开发中我们需要制作比较精美的导航栏。常见的导航栏都是由三部分组成的。 如下图所示, 左边的按钮视图, 中间的视图,右侧的按钮视图。本篇文章我们就来模拟Path这个软件的NavigationBar。

IOS研究院之在IOS5中使用NavigationBar导航栏(八) - 雨松MOMO程序研究院 - 1

 

AppDelegate.h

 

AppDelegate.m

 

MyViewController.m

 

最后我仔细说几个重要的方法。

self.navigationItem.titleView   //导航栏中间显示内容

 self.navigationItem.leftBarButtonItem  //导航栏左侧显示内容

self.navigationItem.rightBarButtonItem //导航栏右侧显示内容

 

 

这个是IOS5独有的方法,可以直接设置导航栏背景图片。

 

最后再说一下拉伸图片的方法 默认在UIImageView中设置Rect属性后中间的图片将会被拉伸,矩形图片被拉伸还好,可是圆角图片被拉伸就会非常不好看。如下图所示,按钮的圆角被拉伸了好多,非常难看。

 

IOS研究院之在IOS5中使用NavigationBar导航栏(八) - 雨松MOMO程序研究院 - 2

 

如下图所示,它就是项目中我们使用到的导航栏按钮的背景图,做过Android的朋友应该会想到9path吧。蛤蛤。其实它们的原理都是一样的,无论是怎么样的圆角图片我们只需要让程序去拉伸图片中央最重要的矩形,而四周的圆角部分不会被拉伸。这样圆角图片无论怎么拉伸都不会出现变形的情况。


IOS研究院之在IOS5中使用NavigationBar导航栏(八) - 雨松MOMO程序研究院 - 3
在代码中我们通过这样的方法来重新得到UIImage对象,参数1表示从左边开始数多少个像素的图片区域不会拉伸,参数2表示从上面开始数多少个像素的图片区域不会被拉伸。

  UIImage *rightbuttonNormal = [rightButtonImage   stretchableImageWithLeftCapWidth:10 topCapHeight:10];

 

细心的朋友可能会想 切图的话 左边 上面参数都给出了为什么没有右边下边呢?其实上面的这个方法会镜像的对应在右侧与下侧,它们都是等比对应的。

 

最后的这个简单DEMO的源代码,希望大家喜欢,雨松MOMO祝大家学习愉快。

源码下载地址:http://vdisk.weibo.com/s/acehY

 

8月13号补充

导航栏中其实还有个比较重要的按钮,就是返回按钮。比如A界面-》B界面,此时B界面左上角应当有一个返回A界面的按钮,然而默认的按钮比较单调,那么我们学习如何自定义这个返回按钮。

如果A界面-》B界面,请把添加返回按钮的代码添加在A界面的ViewController中,因为只有这样当A界面切换至B界面时,B界面就可以看到左上角返回的按钮了。

 

 

效果如下所示

IOS研究院之在IOS5中使用NavigationBar导航栏(八) - 雨松MOMO程序研究院 - 4

最后编辑:
作者:雨松MOMO
专注移动互联网,Unity3D游戏开发
捐 赠写博客不易,如果您想请我喝一杯星巴克的话?就进来看吧!

IOS研究院之在IOS5中使用NavigationBar导航栏(八)》有 6 条评论

  1. 靠谱搜 说:

    感谢分享 收获很大呀

  2. zxm99888 说:

    建议换掉stretchableImageWithLeftCapWidth 改用 resizableImageWithCapInsets

  3. 吼吼,带领一排人,超过雨松MOMO…..哈哈,加油MOMO!!!一直坚持下去!

  4. 博主你写的文章不错,有机会多交流,我也有一个博客,http://lxzngpzh.com/

留下一个回复

你的email不会被公开。