iOS App开发中导航栏的创建及基本属性的教程

来源:爱站网时间:2019-04-01编辑:网友分享
导航条作为iOS开发的一种控件,其实是非常重要的,它可以实现各种效果,如隐藏、透明、导航栏动画等,下面是iOS App开发中导航栏的创建及基本属性的教程,跟着爱站技术频道小编带你来了解一下吧!

导航条作为iOS开发的一种控件,其实是非常重要的,它可以实现各种效果,如隐藏、透明、导航栏动画等,下面是iOS App开发中导航栏的创建及基本属性的教程,跟着爱站技术频道小编带你来了解一下吧!

文件目录如下:基本导航顺序: root -> First -> Second -> Third。其中,FirstViewController作为 navigation堆栈的rootview

201622690834116.jpg (229×371)

1、创建navigation

如果是想直接把navigation导航作为项目一开始的跟视图,把RootViewController.h文件里的nav属性放到AppDelegate.h里即可,再把RootViewController.m文件里的action的代码复制到 AppDelegate.m里的didFinishLaunchingWithOptions 方法里,最后把 self.window.rootViewController 设置 UINavigationController类型的属性nav即可

在RootViewController.h文件

 

#import <UIKit/UIKit.h>
@class FirstViewController;

 

@interface RootViewController : UIViewController

@property (strong, nonatomic) UINavigationController *nav;

- (IBAction)btnClick:(UIButton *)sender;

@end


在RootViewController.m 文件里的随意一个自定义action里:

 

 

 


- (IBAction)btnClick:(UIButton *)sender {
   
    //创建一个viewcontroller
    FirstViewController *fristview =[[[FirstViewController alloc] init] autorelease];
  
   
    //初始化UINavigationController(方式一)
    self.nav = [[[UINavigationController alloc] initWithRootViewController:fristview] autorelease];
   
   
    //初始化UINavigationController(方式二)
  //  self.nav = [[[UINavigationController alloc] init] autorelease];
  //  [self.nav pushViewController:fristview animated:YES];

 

   
    //初始化UINavigationController(方式三,失败,xib文件加载失败,原因暂时不明)
   // self.nav = [[[UINavigationController alloc] initWithNibName:@"FirstViewController" bundle:nil] autorelease];
   
   
    //跳转到FirstView页面
    [self presentViewController:self.nav animated:YES completion:nil];
   
   
    //这种写法一般用于往view里添加一些小控件,如button  label textField之类的,不适宜用于页面跳转
    // [self.view addSubview:self.nav.view];
   
   
}

 

2.navigation的常用属性设置例子
我们的navigation就加载上去了以后,下面我们来设置navigation的属性:

 

- (void)viewDidLoad 

    [super viewDidLoad]; 
    // Do any additional setup after loading the view. 
    [self.navigationController.navigationBar setTranslucent:NO];//设置navigationbar的半透明 
    self.title = @"navigationcontroller";//设置navigationbar上显示的标题 
    [self.navigationController.navigationBar setBarTintColor:[UIColor purpleColor]];//设置navigationbar的颜色 
    self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonItemStyleDone target:self action:Nil];//设置navigationbar左边按钮 
    self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonItemStylePlain target:self action:Nil];//设置navigationbar右边按钮 
    [self.navigationController.navigationBar setTintColor:[UIColor whiteColor]];//设置navigationbar上左右按钮字体颜色 


效果图如下:

 

 

 

201622690858466.png (321×128)

这里还有一个属性常用,就是:

 

 

 

NSArray *arr = [NSArray arrayWithObjects:@"1",@"2", nil nil]; 
    UISegmentedControl *segment = [[UISegmentedControl alloc]initWithItems:arr]; 
    self.navigationItem.titleView = segment;//设置navigation上的titleview 

 

 

效果如下:

201622690937588.png (317×112)

对,我们看到中间的字变成了两个可选的按钮,这就是navigation的另一个属性:navigationitem.titleview。

下面我们再建立一个视图,看一下两个视图之前是怎样通信的。

在第二个视图中,我添加了一个button来显示,并加了一个成员变量来接收从第一个视图中穿过来的值:
 

 

@interface SecondViewController : UIViewController 
@property (copy,nonatomic) NSString *str; 
@end 
 

 

 

 


- (void)viewDidLoad 

    [super viewDidLoad]; 
    // Do any additional setup after loading the view. 
    self.title = @"second"; 
    UIButton *aBUTTON = [[UIButton alloc]initWithFrame:CGRectMake(30, 30, 50, 30)]; 
    [aBUTTON setTitle:_str forState:UIControlStateNormal]; 
    [aBUTTON addTarget:self action:@selector(clicked) forControlEvents:UIControlEventTouchUpInside]; 
    [self.view addSubview:aBUTTON]; 


然后我将第一个视图的右边按钮添加一个事件,点击按钮,就会推出第二个视图,并显示我们传过来的值:
 

 

 

 


- (void)clicked{ 
    SecondViewController *second = [[SecondViewController alloc]init]; 
    [self.navigationController pushViewController:second animated:YES]; 
    second.str = @"hello!!"; 
    [second release]; 


下面,我们来运行一下:

 

 

 

201622691003542.png (316×162)

点进按钮以后,我们的第二个视图推出,button显示了传过来的值。

然后我们点击回button,还有navigation另外一个方法:

 

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


这样就可以回到第一个视图。
以上代码都是爱站技术频道小编为大家搜集的关于iOS App开发中导航栏的创建及基本属性的教程,希望对大家的学习有一定的帮助!

 

上一篇:iOS开发之GDataXML框架解析网络数据的方法

下一篇:IOS开发之跳转系统设置的方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载