首页 > 学院 > 开发设计 > 正文

IOS之导航控制器

2019-11-14 18:07:49
字体:
来源:转载
供稿:网友

  UINavigationController是用于构建分层应用程序的主要工具,主要采用栈形式来实现视图。任何类型的视图控制器都可放入栈中。在设计导航控制器时需要指定根视图即用户看到的第一个视图。根视图控制器是被导航控制器推入到栈中的第一个视图控制器。当用户查看下一个试图时,栈中将加入一个新的视图控制器,它所控制的视图将展示给用户。我们可以通过导航按钮来操作分层的应用程序,用它来控制视图的推入或推出。

1、把子控制器添加到导航控制器中常用的方法

   //创建视图控制器    JRViewController * vc=[[JRViewController alloc] init];          //创建导航控制器,并且将上面的控制器作为导航控制器的根控制器    UINavigationController * naVC=[[UINavigationController alloc] initWithRootViewController:vc];        //将当前的导航控制器设置窗口的根视图控制器self.window.rootViewController=naVC;

2、这样我们就把JRViewController作为了当前导航控制器的根控制器,下面我们进入到JRViewController,并且添加一个标题和按钮代码如下

    //设置背景    self.view.backgroundColor=[UIColor redColor];    //设置标题    self.title=@"精品";     //添加按钮    UIButton * button=[[UIButton alloc] initWithFrame:CGRectMake(0, 0, 100, 45)];    button.backgroundColor=[UIColor blackColor];    [button setTitle:@"push" forState:UIControlStateNormal];    button.center=self.view.center;    [button addTarget:self action:@selector(pushVCNew) forControlEvents:UIControlEventTouchUpInside];    [self.view addSubview:button];

效果图如下:

  3、下面我们就进行视图控制器之间的跳转

  导航控制器管理视图控制器主要采取压栈和出栈的方式,下面我们一起来感受一下如何切换,上面添加了按钮我们增加了点击事件,下面我们重新一下这个点击事件触发的方法:

- (void) pushVCNew{        //初始化第二个控制器    SecondViewController * sec=[[SecondViewController alloc] init];    //切换到另一个视图控制器    [self.navigationController pushViewController:sec animated:YES];    }

效果图如下:

压栈进入后响应的就有出栈,如何进行出栈返回呢,我们重写一下第二个控制器的返回方法,调用控制器的popViewControllerAnimated方法即可

- (void) popVC{    [self.navigationController popViewControllerAnimated:YES];}

5、导航按钮

//1 构造方法    UIBarButtonItem * item1=[[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"bt1"] style:UIBarButtonItemStylePlain target:self action:@selector(leftClick)];            //2 自定义视图    UIButton * button=[[UIButton alloc] initWithFrame:CGRectMake(100, 100, 50, 40)];    button.backgroundColor=[UIColor redColor];    [button setTitle:@"hello" forState:UIControlStateNormal];    UIBarButtonItem * item2=[[UIBarButtonItem alloc] initWithCustomView:button];            //3 添加到当前navigationItem    self.navigationItem.leftBarButtonItem=item2;    self.navigationItem.rightBarButtonItem=item1;        //4 增加标题    UILabel * label=[[UILabel alloc] initWithFrame:CGRectMake(0, 0, 100, 40)];    label.text=@"导航控制器";    label.textColor=[UIColor redColor];self.navigationItem.titleView=label;

效果图如下

6、ToolBar工具条,每个导航控制器都有一个工具条,默认为隐藏状态,下面我们将工具条打开并使用它。

//打开toolbar    self.navigationController.toolbarHidden=NO;     //定义ToolBar增加按钮    UIBarButtonItem * item1=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCancel target:self action:@selector(pushVC)];    UIBarButtonItem * item2=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemSave target:self action:@selector(pushVC)];    UIBarButtonItem * item3=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemBookmarks target:self action:@selector(pushVC)];    UIBarButtonItem * item4=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemOrganize target:self action:@selector(pushVC)];    UIBarButtonItem * item5=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAdd target:self action:@selector(pushVC)];    UIBarButtonItem * item6=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemStop target:self action:@selector(pushVC)];         UIBarButtonItem * item7=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:self action:@selector(pushVC)];      UIBarButtonItem * item8=[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:self action:@selector(pushVC)];    item8.width=20;    //将按钮添加到工具条     self.toolbarItems=@[item1,item8,item2,item8,item3,item8,item4,item7,item5,item8,item6];

效果图如下:

 

作者:杰瑞教育
出处:http://www.VEVb.com/jerehedu/ 
版权声明:本文版权归杰瑞教育技有限公司和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
技术咨询:JRedu技术交流
 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表