iOS开发UINavigation系列一——导航栏UINavigtionBar

iOS开发UINavigation系列一——导航栏UINavigtionBar

一、导航栏的使用

        在iOS开发中,我们通常会使用导航控制器,导航控制器中封装了一个UINavigationBar,实际上,我们也可以在不使用导航控制器的前提下,单独使用导航栏,在UINavigationBar中,也有许多我们可以定制的属性,用起来十分方便。

二、UINavigationBar的创建和风格类型

        导航栏继承于UIView,所以我们可以像创建普通视图那样创建导航栏,比如我们创建一个高度为80的导航栏,将其放在ViewController的头部,代码如下:

?


1

2

UINavigationBar *bar = [[UINavigationBar alloc]initWithFrame:CGRectMake(0, 0, 320, 80)];

[self.view addSubview:bar];

效果如下:

        

我们也可以设置导航栏的风格属性,从iOS6之后,UINavigationBar默认为半透明的样式,从上面也可以看出,白色的导航栏下面透出些许背景的红色。导航栏的风格属性可以通过下面的属性来设置:

?


1

@property(nonatomic,assign) UIBarStyle barStyle;

UIBarStyle是一个枚举,其中大部分的样式都已弃用,有效果的只有如下两个:

?


1

2

3

4

typedef NS_ENUM(NSInteger, UIBarStyle) {

    UIBarStyleDefault          = 0,//默认

    UIBarStyleBlack            = 1,//黑色

}

默认的风格就是我们上面看到的白色的风格,黑色的风格效果瑞如下:

三、导航栏常用属性和方法

        从上面我们可以看到,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

2

- (void)setBackgroundImage:(nullable UIImage *)backgroundImage forBarMetrics:(UIBarMetrics)barMetrics NS_AVAILABLE_IOS(5_0) UI_APPEARANCE_SELECTOR;

- (nullable UIImage *)backgroundImageForBarMetrics:(UIBarMetrics)barMetrics;

上面两个方法用于设置和获取导航栏的背景图案,这里需要注意,默认背景图案是不做缩放处理的,所以我们使用的图片尺寸要和导航栏尺寸匹配,这里面还有一个UIBarMetrics参数,这个参数设置设备的状态,如下:

?


1

2

3

4

typedef NS_ENUM(NSInteger, UIBarMetrics) {

    UIBarMetricsDefault,//正常竖屏状态

    UIBarMetricsCompact,//横屏状态

};

?


1

2

3

4

//设置导航栏的阴影图片

@property(nullable, nonatomic,strong) UIImage *shadowImage;

//设置导航栏的标题字体属性

@property(nullable,nonatomic,copy) NSDictionary<NSString *,id> *titleTextAttributes;

标题字体属性会影响到导航栏的中间标题,如下:

?


1

   bar.titleTextAttributes = @{NSForegroundColorAttributeName:[UIColor redColor]};

我们也可以通过下面的属性设置导航栏标题的竖直位置偏移:

?


1

2

- (void)setTitleVerticalPositionAdjustment:(CGFloat)adjustment forBarMetrics:(UIBarMetrics)barMetrics;

- (CGFloat)titleVerticalPositionAdjustmentForBarMetrics:(UIBarMetrics)barMetrics;

还有一个细节,导航栏左侧pop按钮的图案默认是一个箭头,我们可以使用下面的方法修改:

?


1

2

@property(nullable,nonatomic,strong) UIImage *backIndicatorImage;

@property(nullable,nonatomic,strong) UIImage *backIndicatorTransitionMaskImage;

四、导航栏中item的push与pop操作

        UINavigationBar上面不只是简单的显示标题,它也将标题进行了堆栈的管理,每一个标题抽象为的对象在iOS系统中是UINavigationItem对象,我们可以通过push与pop操作管理item组。

?


1

2

3

4

5

6

7

8

9

10

11

12

//向栈中添加一个item,上一个item会被推向导航栏的左侧,变为pop按钮,会有一个动画效果

- (void)pushNavigationItem:(UINavigationItem *)item animated:(BOOL)animated;

//pop一个item

- (nullable UINavigationItem *)popNavigationItemAnimated:(BOOL)animated; 

//当前push到最上层的item

@property(nullable, nonatomic,readonly,strong) UINavigationItem *topItem;

//仅次于最上层的item,一般式被推向导航栏左侧的item

@property(nullable, nonatomic,readonly,strong) UINavigationItem *backItem;

//获取堆栈中所有item的数组

@property(nullable,nonatomic,copy) NSArray<UINavigationItem *> *items;

//设置一组item

- (void)setItems:(nullable NSArray<UINavigationItem *> *)items animated:(BOOL)animated;

五、UINavigationBarDelegate

        在UINavigationBar中,还有如下一个属性:

?


1

@property(nullable,nonatomic,weak) id<UINavigationBarDelegate> delegate;

通过代理,我们可以监控导航栏的一些push与pop操作:

?


1

2

3

4

5

6

7

8

//item将要push的时候调用,返回NO,则不能push

- (BOOL)navigationBar:(UINavigationBar *)navigationBar shouldPushItem:(UINavigationItem *)item; 

//item已经push后调用

- (void)navigationBar:(UINavigationBar *)navigationBar didPushItem:(UINavigationItem *)item; 

//item将要pop时调用,返回NO,不能pop  

- (BOOL)navigationBar:(UINavigationBar *)navigationBar shouldPopItem:(UINavigationItem *)item; 

//item已经pop后调用 

- (void)navigationBar:(UINavigationBar *)navigationBar didPopItem:(UINavigationItem *)item;


时间: 2024-08-04 06:06:35

iOS开发UINavigation系列一——导航栏UINavigtionBar的相关文章

iOS开发UINavigation系列四——导航控制器UINavigationController

iOS开发UINavigation系列四--导航控制器UINavigationController 一.引言         在前面的博客中,我么你介绍了UINavigationBar,UINavigationItem和UIToolBar,UINavigationController是将这些控件和UIViewController紧密的结合了起来,使用导航,我们的应用程序层次会更加分明,对controller的管理也更加方便.前几篇博客地址如下: UINavigationBar:http://my

iOS开发UINavigation系列三——工具栏UIToolBar

iOS开发UINavigation系列三--工具栏UIToolBar         iOS中除了UINavinationBar之外,还有工具栏UIToolBar可以供我们使用,工具栏和导航栏十分类似,只是功能更加简单,工具栏中也有UIBarButtonItem按钮,在前两篇博客中,对导航栏和导航项都进行的讨论,地址如下: UINavigationBar:http://my.oschina.net/u/2340880/blog/527706 UINavigationItem:http://my.

iOS开发UINavigation系列二——UINavigationItem

iOS开发UINavigation系列二--UINavigationItem 一.引言         UINavigationItem是导航栏上用于管理导航项的类,在上一篇博客中,我们知道导航栏是通过push与pop的堆栈操作来对item进行管理的,同样,每一个Item自身也有许多属性可供我们进行自定制.这篇博客,主要讨论UINavigationItem的使用方法. UINavigationBar:http://my.oschina.net/u/2340880/blog/527706. 二.来

iOS开发之如何修改导航栏的内容

导航栏的内容由栈顶控制器的navigationItem属性决定. UINavigationItem有以下属性影响着导航栏的内容(通常在子控制器中viewDidLoad方法中调用这些方法): 左上角的返回按钮: @property(nonatomic,retain) UIBarButtonItem *backBarButtonItem; 例如:self.navigationItem.backBarButtonItem = [[UIBarButtonItem alloc] initWithTitle

iOS实现顶部标签式导航栏及下拉分类菜单_IOS

本文实例为大家分享了iOS实现顶部标签式导航栏及下拉分类菜单的全部过程,供大家参考,具体内容如下 当内容及分类较多时,往往采用顶部标签式导航栏,例如网易新闻客户端的顶部分类导航,最近刚好有这样的应用场景,参考网络上一些demo,实现了这种导航效果,记录一些要点. 效果图(由于视频转GIF掉帧,滑动和下拉动画显得比较生硬,刚发现quickTime可以直接录制手机视频,推荐一下,很方便) 1.顶部标签式导航栏 (1)实现思路 其实就是在上下两个UIScrollView上做文章,实现联动选择切换的效果

IOS开发:Web App导航设计探讨

 开发:Web App导航设计探讨-app导航设计"> 导航系统所遭遇的挑战 iPhone Native App较常见的导航如下图所示: 手机屏幕底端:A.B.C.D四个tab组成该Native App的全局导航,这是我们经常见到的tab导航栏. 手机屏幕顶端:主要有四种形式.第①种形式是在该位置中心显示产品的logo;也可以将logo适当调整位置,将常用操作或快捷入口放在该位置的右侧.第②种形式是在该位置有两或三个tab选项.第③种形式是在该位置中间显示当前任务标题,在左右两侧放置导航控

ios开发-程序运行正常,模拟器没有显示

问题描述 程序运行正常,模拟器没有显示 现在在自学ios开发,学到分页栏与选取器这里,程序运行正常,可是模拟器完全空白,想问下这是什么原因?谢谢! 解决方案 你可以把程序的入口控制器,改成你这个BIDatePickerViewController,看代码应该可以显示,可能是storyboard上的View Controller与代码的View Controller不相符所产生的问题

iOS应用开发中导航栏按钮UIBarButtonItem的添加教程_IOS

1.UINavigationController导航控制器如何使用 UINavigationController可以翻译为导航控制器,在iOS里经常用到. 我们看看它的如何使用: 下面的图显示了导航控制器的流程.最左侧是根视图,当用户点击其中的General项时 ,General视图会滑入屏幕:当用户继续点击Auto-Lock项时,Auto-Lock视图将滑入屏幕.相应地,在对象管理上,导航控制器使用了导航堆栈.根视图控制器在堆栈最底层,接下来入栈的是General视图控制器和Auto-Lock

ios开发碰到自定义导航栏leftBarButtonItems导致滑动返回失效问题解决方法

通常使用导航控制器 navigationController 跳转到另一页面时,除了可以点击左上角的返回按钮,还可以通过在屏幕左侧向右滑动来返回到上一层.但如果自定义了 self.navigationItem.leftBarButtonItems 后会发现,滑动返回(swipe back)失效了. (如何自定义导航栏左侧按钮可以看这篇文章:Swift - 修改导航栏"返回"按钮文字,图标) 开发碰到自定义导航栏leftBarButtonItems导致滑动返回失效问题解决方法-leftb