iOS开发UINavigation系列一——导航栏UINavigtionBar
iOS开发UINavigation系列一——导航栏UINavigtionBar
一、导航栏的使用
在iOS开发中,我们通常会使用导航控制器,导航控制器中封装了一个UINavigationBar,实际上,我们也可以在不使用导航控制器的前提下,单独使用导航栏,在UINavigationBar中,也有许多我们可以定制的属性,用起来十分方便。
二、UINavigationBar的创建和风格类型
导航栏继承于UIView,所以我们可以像创建普通视图那样创建导航栏,比如我们创建一个高度为80的导航栏,将其放在ViewController的头部,代码如下:
1 | UINavigationBar *bar = [[UINavigationBar alloc]initWithFrame:CGRectMake(0, 0, 320, 80)]; |
效果如下:
我们也可以设置导航栏的风格属性,从iOS6之后,UINavigationBar默认为半透明的样式,从上面也可以看出,白色的导航栏下面透出些许背景的红色。导航栏的风格属性可以通过下面的属性来设置:
1 | @property(nonatomic,assign) UIBarStyle barStyle; |
UIBarStyle是一个枚举,其中大部分的样式都已弃用,有效果的只有如下两个:
1 | typedef NS_ENUM(NSInteger, UIBarStyle) { |
默认的风格就是我们上面看到的白色的风格,黑色的风格效果瑞如下:
三、导航栏常用属性和方法
从上面我们可以看到,iOS6后导航栏默认都是半透明的,我们可以通过下面的bool值来设置这个属性,设置为NO,则导航栏不透明,默认为YES:
1 | @property(nonatomic,assign,getter=isTranslucent) BOOL translucent; |
下面一些方法用于设置NavigationBar及上面item的颜色相关属性:
1 | @property(null_resettable, nonatomic,strong) UIColor *tintColor; |
tintColor这个属性会影响到导航栏上左侧pop按钮的图案颜色和字体颜色,系统默认是如下颜色:
1 | @property(nullable, nonatomic,strong) UIColor *barTintColor; |
BarTintColor用于设置导航栏的背景色,这个属性被设置后,半透明的效果将失效:
1 | - (void)setBackgroundImage:(nullable UIImage *)backgroundImage forBarMetrics:(UIBarMetrics)barMetrics NS_AVAILABLE_IOS(5_0) UI_APPEARANCE_SELECTOR; |
上面两个方法用于设置和获取导航栏的背景图案,这里需要注意,默认背景图案是不做缩放处理的,所以我们使用的图片尺寸要和导航栏尺寸匹配,这里面还有一个UIBarMetrics参数,这个参数设置设备的状态,如下:
1 | typedef NS_ENUM(NSInteger, UIBarMetrics) { |
1 | //设置导航栏的阴影图片 |
标题字体属性会影响到导航栏的中间标题,如下:
1 | bar.titleTextAttributes = @{NSForegroundColorAttributeName:[UIColor redColor]}; |
我们也可以通过下面的属性设置导航栏标题的竖直位置偏移:
1 | - (void)setTitleVerticalPositionAdjustment:(CGFloat)adjustment forBarMetrics:(UIBarMetrics)barMetrics; |
还有一个细节,导航栏左侧pop按钮的图案默认是一个箭头,我们可以使用下面的方法修改:
1 | @property(nullable,nonatomic,strong) UIImage *backIndicatorImage; |
四、导航栏中item的push与pop操作
UINavigationBar上面不只是简单的显示标题,它也将标题进行了堆栈的管理,每一个标题抽象为的对象在iOS系统中是UINavigationItem对象,我们可以通过push与pop操作管理item组。
1 | //向栈中添加一个item,上一个item会被推向导航栏的左侧,变为pop按钮,会有一个动画效果 |
五、UINavigationBarDelegate
在UINavigationBar中,还有如下一个属性:
1 | @property(nullable,nonatomic,weak) id<UINavigationBarDelegate> delegate; |
通过代理,我们可以监控导航栏的一些push与pop操作:
1 | //item将要push的时候调用,返回NO,则不能push |
专注技术,热爱生活,交流技术,也做朋友。
——珲少 QQ群:203317592