iOS学习之UINavigationController

时间:2021-07-01 18:39:34
一、UINavigationController
     1、UINavigationController:导航控制器,是iOS中最常用的多视图控制器之一,用它来管理多个视图控制器。可以称为是管理控制器的控制器,主要管理有层次递进关系的控制器。
     2、UINavigationController继承于UIViewController,以栈的方式管理所控制的视图控制器,至少要有一个被管理的视图控制器,这个控制器我们称作,导航控制器的根视图控制器。
  • 任何继承自UIViewController的类(多态)都可以作为根控制器。
     3、UINavigationController的创建
  在AppDelegate.m
    // 创建UIWindow对象
    self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];

    // 设置背景颜色
    self.window.backgroundColor = [UIColor whiteColor];

    // 使window显示
    [self.window makeKeyAndVisible];

    // 创建视图控制器,给window指定根控制器,设置导航控制器
    self.window.rootViewController = [[UINavigationController alloc] initWithRootViewController:[[RootViewController alloc] init]];
二、UINavigationBar
     1、概述
  • UINavigationBar(导航栏)上的设置主要分两部分,一为导航栏上的各种导航部件(UINavigationItem),二为导航栏自身的相关设置。
  • navigationBar——导航条,iOS7之后默认是半透明的,iOS7之前默认是不透明的。
  • navigationBar竖屏下默认高度44,横屏下默认高度32。
  • iOS7之后,navigationBar的背景会延伸到statusBar上。导航栏高度仍保持44,但显示效果为64.
  • 每个视图控制器都有一个navigationItem属性。navigationItem中设置的左按钮、右按钮、标题等,会随着控制器的显示,也显示到navigationBar上。
     2、常用属性
  在RootViewController.m中
#import "RootViewController.h"

@interface RootViewController ()

@end

@implementation RootViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.view.backgroundColor = [UIColor brownColor];

    // 设置导航控制器
    [self initLayout];
}

// 初始化布局(实现布局的方法)
- (void)initLayout
{
    // 导航控制器的显示隐藏属性(YES == 隐藏, NO == 显示)
    self.navigationController.navigationBarHidden = NO;

    // UINavigationBar(导航条,iOS7.0 之后导航条默认有半透明属性)
    // 设置导航条是否开启半透明效果(会影响self.subViews的坐标系,当半透明效果开启时,self.view以屏幕左上角为坐标原点,关闭时,导航条左下角为坐标原点)
    self.navigationController.navigationBar.translucent = NO;

    // 修改导航条颜色,状态栏颜色默认与导航条颜色相同
    self.navigationController.navigationBar.barTintColor = [UIColor grayColor];

    // 导航条背景颜色
    self.navigationController.navigationBar.backgroundColor = [UIColor redColor];

    // 设置导航条标题
//    self.title = @"根视图";
    // navigationItem属性,用来设置子控件
    self.navigationItem.title = @"根视图";

    // 左按钮
    self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"左按钮" style:UIBarButtonItemStylePlain target:self action:@selector(leftItemAciton:)];

    // 右按钮
    // 一个按钮
//    self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCancel target:self action:@selector(rightItemClick:)];
//
//    self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"next"] style:UIBarButtonItemStylePlain target:self action:@selector(rightItemClick:)];

    // 多个按钮, 自动排序

    UIBarButtonItem *item1 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCamera target:self action:@selector(rightItemClick:)];

    UIBarButtonItem *item2 =[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemReply target:self action:@selector(rightItemClick:)];

    self.navigationItem.rightBarButtonItems = @[item2, item1];

    // 设置导航元素的颜色
    self.navigationController.navigationBar.tintColor = [UIColor whiteColor];

    // 导航栏样式
    self.navigationController.navigationBar.barStyle = UIBarStyleBlack;

    // 标题视图

    UISegmentedControl *segment = [[UISegmentedControl alloc] initWithItems:@[@"男神", @"女神", @"-1"]];
    segment.frame = CGRectMake(, , , );
    segment.selectedSegmentIndex = ;
    [segment addTarget:self action:@selector(segmentAction:) forControlEvents:UIControlEventValueChanged];

    self.navigationItem.titleView = segment;

    UIView *view = [[UIView alloc] initWithFrame:CGRectMake(, , , )];
    view.backgroundColor = [UIColor lightGrayColor];
    [self.view addSubview:view];

}
// 实现左按钮方法
- (void)leftItemAciton:(UIBarButtonItem *)sender
{
    NSLog(@"跟着我左手 慢动作");
}
- (void)segmentAction:(UISegmentedControl *)sender
{
    switch (sender.selectedSegmentIndex) {
        :
            self.view.backgroundColor = [UIColor colorWithRed: green: blue:  alpha:];
            break;
        :
            self.view.backgroundColor = [UIColor colorWithRed: green: blue:  alpha:];
            break;
        :
            self.view.backgroundColor = [UIColor colorWithRed: green: blue:  alpha:];
            break;

        default:
            break;
    }

}

// 实现右按钮方法
- (void)rightItemClick:(UIBarButtonItem *)sender
{
    NSLog(@"跟着我右手 慢动作重播");
}
@end
     3、导航控制器左右按钮中英文的问题(例cancle / 取消),在工程设置->info->Localization native development region->China
  • iOS学习之UINavigationController
三、页面跳转
     1、工作原理
  • UINavigationController通过栈的方式管理控制器的切换,控制入栈和出栈来展示各个视图控制器。
  • UINavigationController的ContentView里始终显示栈顶控制器的view。
  • viewControllers属性是一个可变数组(NSMutableArray)存储了栈中说的所有被管理的控制器,入栈的时候,使用addObject把新的视图控制器对象添加到数组末尾,出栈时removeLastObject移除数组末尾的视图控制器对象。
  • navigationController属性,父类中的属性,每个栈中的控制器,都能通过此属性,获取自己所在的UINavigationController对象。
  • 栈的特点:先进后出,后进先出。
     2、常用属性
  • iOS学习之UINavigationController
  • iOS学习之UINavigationController
    // 实现按钮方法
- (void)btnAction:(UIButton *)sender
{
    // 创建第一页的对象
    FirstViewController *fVC = [[FirstViewController alloc] init];
    // 通过导航控制器推出新的页面
    [self.navigationController pushViewController:fVC animated:YES];
}
- (void)popButtonAction:(UIButton *)sender
{
    // 返回上一个视图
    [self.navigationController popViewControllerAnimated:YES];

    // 返回指定视图
    [self.navigationController popToViewController:self.navigationController.viewControllers[] animated:YES];
    // 返回根视图
    [self.navigationController popToRootViewControllerAnimated:YES];
}
四、模态
     1、页面切换方式对比
  • 页面的切换方式主要分为:推出(push)和模态(present)。
  • 推出用于一系列的视图之间的跳转有层次递进关系。
  • 模态用于单独功能页面的跳转和主要业务逻辑没有关联(登录,歌曲播放页,系统相册,应用中调出系统功能)。
     2、添加过渡动画(有默认值)
- (void)modelBtnAction:(UIButton *)sender
{
    // 创建第二页对象
    ShowViewController *sVC = [[ShowViewController alloc] init];
    // 给第二页设置导航控制器
    UINavigationController *sNVC = [[UINavigationController alloc] initWithRootViewController:sVC];
    // 添加模态动画
    sVC.modalTransitionStyle = UIModalTransitionStyleCoverVertical;
    // 模态跳到下一个页面
    [self.navigationController presentViewController:sNVC animated:YES completion:nil];
}
- (void)backBtnAction:(UIButton *)sender
{
    // 模态返回上一个视图
    [self dismissViewControllerAnimated:YES completion:nil];
}
// 模态动画的效果// UIModalTransitionStylePartialCurl 翻页方式 推出
// UIModalTransitionStyleFlipHorizontal 水平旋转方式 推出
// UIModalTransitionStyleCrossDissolve 交叉叠化溶解方式 推出
// UIModalTransitionStyleCoverVertical 垂直覆盖方式 推出