服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS App开发中导航栏的创建及基本属性设置教程

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

2021-01-08 14:16苹果吧 IOS

这篇文章主要介绍了iOS App开发中导航栏的创建及基本属性设置教程,即用UINavigationController来编写navigation,示例代码为Objective-C语言,需要的朋友可以参考下

文件目录如下:基本导航顺序: root -> first -> second -> third。其中,firstviewcontroller作为 navigation堆栈的rootview

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

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上左右按钮字体颜色 


效果图如下:

 

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

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

 

复制代码 代码如下:

 

nsarray *arr = [nsarray arraywithobjects:@"1",@"2", nil nil]; 
    uisegmentedcontrol *segment = [[uisegmentedcontrol alloc]initwithitems:arr]; 
    self.navigationitem.titleview = segment;//设置navigation上的titleview 

 

 

效果如下:

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

对,我们看到中间的字变成了两个可选的按钮,这就是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]; 


下面,我们来运行一下:

 

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

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

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

复制代码 代码如下:

- (void)clicked{ 
    [self.navigationcontroller popviewcontrolleranimated:yes]; 


这样就可以回到第一个视图。

延伸 · 阅读

精彩推荐
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22