导航控制器 NavigationController

2023-12-27 11:58

本文主要是介绍导航控制器 NavigationController,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

UINavigationController

1> 作用:

管理其他控制器的控制器,能够记录多个控制器层层推进的顺序,便于在实现多vc切换时,保证vc的顺序

2> 如何实现管理的vc的切换

[vc.navigationController   pushViewController:界面];

 

3>特点

导航控制器并且没有一个独立完整的用于显示的界面,依靠正在管理的普通的vc的view做为当前显示的界面.在屏幕顶端导航控制器自带一个导航条(Navigation Bar),在屏幕下方的导航控制器自带了一个工具条(Tool Bar)

4>配置导航条

访问整个导航条:  vc.navigationItem

左,右: UIBarButtonItem对象

vc.navigationItem.leftBarButtonItem

vc.navigationItem.rightBarButtonItem

中: 文字或其他的控件

vc.navigationItem.title

vc.navigationItem.titleView 

5>配置工具条

位置:位于屏幕的底部,默认是隐藏的

配置如何显示

vc.navigationController.toolBarHidden = NO;

配置工具条中的内容

工具条中能够容纳的只能是UIBarButtonItem类型的按钮

vc.toolBarItems

特效按钮:

木棍和弹簧按钮,可以在toolBar中,调整按钮之间的间距,木棍(Fix)的特点是长度固定,弹簧(Flexiable)的特点是长度可以自适应

6>导航控制器的实现原理

导航控制器具有一个viewControllers的属性,是数组类型的,并且是以 “栈”特殊的存储方式管理数组中的元素

数组 — 下标 有序

字典 —  根据key找到value

“栈”—— 先进后出,后进先出

往 “栈”中存数据: 入栈 压栈  push

从 “栈”中取数据: 出栈 弹栈  pop

“队列”—— 先进先出,后进后出

  7> 导航控制器的属性的作用域范围

vc.navigationController.toolBarHidden 

vc.navigationController.navigationBarHidden 

以上两个用于设置显示隐藏的属性(可跨多个VC),作用域为多个vc,不管在哪个vc中,一旦修改了hidden属性,那么,就算是切换到其他的vc,修改过的hidden属性仍然生效

vc.navigationItem.left/right BarButtonItem

vc.navigationItem.title/view

vc.toolBarItems 

以上用于设置导航栏和工具栏内容的属性,作用域只在当前正在加载的vc中有效, 如果切换到另一个vc,那么在上一个vc中设置的这些内容就都不再生效

8>多导航控制器之前的切换

UINavigationController 继承自UIViewController,所以UIViewController可以present+dismiss(上下推),那么两个UINavigationController 之间 也可以 present+dismiss

什么时候需要在两个导航之间切换?

一个导航一般用于管理一套流程操作中的多个界面,整个应用,包含多套操作流程,所以,在一个应用中就会有多个导航存在,那么当需要从一个流程调到另个流程中时,就需要从一个导航调到另一个导航

[vc.navigationController presentViewController:otherNavi];

[vc.navigationController dismissViewController];

设置NavigationController

    UINavigationController *navController = [[UINavigationController alloc]initWithRootViewController:controller];

    navController.delegate = self;

   if ([navController.navigationBar respondsToSelector:@selector(setBackgroundImage:forBarMetrics:)])

    {

        [navController.navigationBar setBackgroundColor:[UIColor clearColor]];

//        [navController.navigationBar setBackgroundImage:[[UIImage imageWithColor:SHColor_navbkg size:CGSizeMake(ScreenWidth, 3)] stretchableImageWithLeftCapWidth:100.f topCapHeight:1] forBarMetrics:UIBarMetricsDefault];

    }

    //设置字体

   NSShadow * shadow = [[NSShadow alloc] init];

    [shadow setShadowColor: [UIColor colorWithWhite:1.0f alpha:1.f]];

    [shadow setShadowOffset: CGSizeMake(0.5f, 0.0f)];

    navController.navigationBar.tintColor = [UIColor whiteColor];

    [navController.navigationBar setTitleTextAttributes:

     @{ NSForegroundColorAttributeName: [UIColor whiteColor],

        NSFontAttributeName: [UIFont boldSystemFontOfSize:18.f],

        NSShadowAttributeName: shadow}];

    

   [[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(-1000, -100) forBarMetrics:UIBarMetricsDefault];

 

 

 

1.将导航控制器设置为window的根视图控制器

MyViewController *myVC = [[MyViewController alloc]init];

UINavigationController *navi = [[UINavigationController alloc]

  initWithRootViewController:myVC];    

self.window.rootViewController = navi; 

[self.window makeKeyAndVisible];

2.设置导航栏

1>设置导航栏是否隐藏

self.navigationController.navigationBarHidden=YES;(默认显示)

2>设置导航栏文字按钮

UIBarButtonItem *item1 = [[UIBarButtonItem alloc]initWithTitle:

  @"OK" style:UIBarButtonItemStylePlain target:self action:@selector(clickOK:)];

3>设置导航栏图片按钮

UIBarButtonItem *item2 = [[UIBarButtonItem alloc]initWithImage:

  [UIImage imageNamed:@"quan.png"] style:UIBarButtonItemStylePlain target:nil  

  action:nil]; 

4>配置了导航栏的右边按钮,按钮顺序从右往左排列

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

5>配置导航栏的左按钮

self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc]

  initWithBarButtonSystemItem:UIBarButtonSystemItemCamera target:nil 

  action:nil]; 

6>创建导航条中间按钮【普通按钮】

UIButton *button = [[UIButton alloc]initWithFrame: CGRectMake(0, 0, 200, 40)];

//x和y设置多少都无效

.设置按钮名和插入图片

[button setTitle:@"选择分组" forState:UIControlStateNormal];

[button setImage:[UIImage imageNamed:@"arrow_down.png"] forState:

  UIControlStateNormal]; 

//若需按钮从normal切换为selected状态必须修改按钮的selected属性为YES [button setImage:[UIImage imageNamed:@"arrow_up.png"] forState:

  UIControlStateSelected];//button.selected属性的真假决定该句是否执行。

.设置导航中间按钮某种状态时文字颜色

[button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal]; 

[button setTitleColor:[UIColor redColor] forState:UIControlStateSelected];

.为按钮添加事件

[button addTarget:self action:@selector(clickTitleButton:) forControlEvents:

  UIControlEventTouchUpInside];

.按钮添加到视图titleView中

self.navigationItem.titleView = button; 

.在按钮的响应方法中实现按钮状态的切换

-(void)clickTitleButton:(UIButton *)btn{  

btn.selected = !btn.selected; //通过修改selected属性,实现按钮切换

}

3.设置工具条

1>设置工具条显示, (下界面需要隐藏时,需要在界面推出前修改设置)

self.navigationController.toolbarHidden = NO; //默认隐藏

[self.navigationController setNavigationBarHidden:NO];

2>创建工具条系统按钮

.创建播放器按钮

UIBarButtonItem *item3 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:

 UIBarButtonSystemItemPlay target:nil action:nil];

 UIBarButtonSystemItemPlay //播放

 UIBarButtonSystemItemFastForward//快进

 UIBarButtonSystemItemRewind//快速倒回 

.创建木棍按钮

UIBarButtonItem *itemFix = [[UIBarButtonItem alloc]

 initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil  

 action:nil]; 

itemFix.width = 40; //设置木棍的宽度   

.创建弹簧按钮 

UIBarButtonItem *itemFlexible = [[UIBarButtonItem alloc]

 initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil  

 action:nil]; 

.工具条创建按钮的排列【从左往右】

self.toolbarItems =

  @[itemFix,item5,itemFlexible,item3,itemFlexible,item4,itemFix];    

4.导航控制器一旦推出新的界面,导航栏和工具栏的内要由该界面的控制器决定

5.推出新的界面后,导航栏自动有“返回”左按钮,可以自己重建“返回”左按钮覆盖系统,

6.在推出下一界面前作以下设置隐藏下部工具条Bar vc.hidesBottomBarWhenPushed = YES;//当推出vc时隐藏vc底部的各种Bar包括(ToolBar,TabBar),返回上一界面底部的Bar不受影响

self.navigationController.toolbarHidden = NO;//返回上一界面底部TooBar也被隐藏了【该属性可跨界面】

 

这篇关于导航控制器 NavigationController的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/543049

相关文章

jmeter之仅一次控制器

仅一次控制器作用: 不管线程组设置多少次循环,它下面的组件都只会执行一次 Tips:很多情况下需要登录才能访问其他接口,比如:商品列表、添加商品到购物车、购物车列表等,在多场景下,登录只需要1次,我们期望的是重复执行登陆后面的接口来做压测,这就和事务相关,例如 事务1: 登录—>添加购物车 事务2: 登录—>购物车列表 事务3: 登录—>商品列表—>添加购物车 … 一、仅一次控制器案例 在

为控制器的方法添加必要参数

前言:做这个系统时,要求每次调用接口时要传操作人、操作人电脑ip、菜单id,然后计入log。本来前端读取到然后加入请求头,后端写入log即可。但是老大要求后端也要把控必传参数,避免前端忘记。所以就写了这个。IOperationFilter 这个是百度知道的。主要用于在Swagger生成的API文档中动态地添加或修改操作(即API接口)的元数据。 用处:可以自动地为 Swagger/OpenAPI

IBM Storwize V7000存储控制器故障节点报错574

背景:由于客户机房搬迁,需要下电迁移设备。该存储自2016年投入生产使用后,从未关过机,已正常运行七八年时间,期间只更换过硬盘,无其他硬件故障。 在GUI界面点击关闭系统后,大概等了40分钟,存储仍未关机,所有硬盘状态灯绿色常亮,面板无报错。到设备后面看控制器的状态,发现node2已经正常关机了,node1仍然在运行,又等了大概20分钟还没有关机,直接将电源线给拔掉了。 再次上电以后,发现

s3c2440---中断控制器

一、概述 S3C2440A 中的中断控制器接受来自 60 个中断源的请求。提供这些中断源的是内部外设,如 DMA 控制器、 UART、IIC 等等。 在这些中断源中,UARTn、AC97 和 EINTn 中断对于中断控制器而言是“或”关系。 当从内部外设和外部中断请求引脚收到多个中断请求时,中断控制器在仲裁步骤后请求 ARM920T 内核的 FIQ 或 IRQ。 仲裁步骤由硬件优先级逻辑决定

CSS学习6--背景图片、颜色、位置、附着、简写、透明、缩放、多背景、凹凸文字、导航栏例子

CSS背景 一、背景颜色和图片二、背景位置三、背景附着四、背景简写五、背景透明六、背景缩放七、多背景八、凹凸文字九、导航栏例子 一、背景颜色和图片 background-color: pink; 背景颜色backgroundoimage: url(##.jpg); 背景图片background-repeat: 平铺 repeat-x横向平铺,repeat-y纵向平铺; 平铺不到

【风力发电】基于智能控制器的光伏/风电混合发电系统

摘要 光伏和风力发电因其可再生性和环保性在全球范围内得到了广泛应用。本文提出了一种基于智能控制器的光伏/风电混合发电系统,通过智能控制器对系统的功率输出进行优化管理。实验结果表明,该系统能够在不同的环境条件下高效运行,显著提高了能源利用率和系统稳定性。 理论 光伏/风电混合发电系统结合了太阳能和风能的优势,能够更好地适应不同的气候条件。然而,由于太阳辐射和风速的变化性,这种系统的功率输出

Win10 - 删除快速访问导航栏

1、按下 Win + R 键,在运行中输入 regedit 回车,打开注册表 2、然后定位到 HKEY_CLASSES_ROOT\CLSID\{679f85cb-0220-4080-b29b-5540cc05aab6}\ShellFolder 中 3、这时需要对 ShellFolder 进行权限修改,不然是没法修改该项下的数据。参考 Win10注册表获取权限的方法 4、得到权限后,再把把右

kubernetes里面那些事————控制器

资源-控制器 一,控制器作用二,控制器类型2.1,Deployment:无状态应用部署2.2,DaemonSet:确保所有Node运行同一个pod2.3,StatefulSet:有状态应用部署2.4,Job:一次性任务2.5,CronJob:定时任务2.6,pod2.7,service2.8,replicaset2.9,endpoints 三,控制器yaml应用3.1,Deployment3

C1-2 ABB二次SDK开发——手把手教登录对应的机器人控制器(图片引导操作)登录机器人控制器和刷新机器人列表

1.完成配置后我们开始进行操作 C1-1 ABB二次SDK开发——C#Window窗体-环境配置(带ABB二次开发SDK资源包)-CSDN博客文章浏览阅读95次。3.记住路径,右键C#引用,然后导入ABB.Robotics.Controllers.PC.dll。2.安装资源文件PCABB二次开发的SDK,并打开安装路径。1.新建VSC#的windowfrom项目。4.在框架代码主界面代码中添加。

【unity实战】利用Root Motion+Blend Tree+Input System+Cinemachine制作一个简单的角色控制器

文章目录 前言动画设置Blend Tree配置角色添加刚体和碰撞体代码控制人物移动那么我们接下来调整一下相机的视角效果参考完结 前言 Input System知识参考: 【推荐100个unity插件之18】Unity 新版输入系统Input System的使用,看这篇就够了 Cinemachine虚拟相机知识参考: 【推荐100个unity插件之10】Unity最全的最详细的C