zoukankan      html  css  js  c++  java
  • ios UINavigationController

    转自:http://www.cnblogs.com/ios8/p/ios-UINavigationController.html

    UINaviGationController通常被我们称为导航栏,他是视图与视图之间联系沟通的桥梁,一些著名的app都用到了他。下面我们来看一下如何建立一个navigation。

    首先,我们通常新建工程是直接将视图控制器添加到window上,而现在有navigation以后,就多了一层:

         Appdelegete.h: 

    1. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions  
    2. {  
    3.     self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];  
    4.     // Override point for customization after application launch.  
    5.     self.window.backgroundColor = [UIColor whiteColor];  
    6.     RootViewController *root = [[RootViewController alloc]init];  
    7.     UINavigationController *nav = [[UINavigationController alloc]initWithRootViewController:root];//先将root添加在navigation上  
    8.     [_window setRootViewController:nav];//navigation加在window上  
    9.       
    10.     [nav release];  
    11.     [root release];  
    12.       
    13.     [self.window makeKeyAndVisible];  
    14.     return YES;  
    15. }  

    这样我们的navigation就加载上去了。下面我们来设置navigation的属性:

      

    1. - (void)viewDidLoad  
    2. {  
    3.     [super viewDidLoad];  
    4.     // Do any additional setup after loading the view.  
    5.     [self.navigationController.navigationBar setTranslucent:NO];//设置navigationbar的半透明  
    6.     self.title = @"navigationcontroller";//设置navigationbar上显示的标题  
    7.     [self.navigationController.navigationBar setBarTintColor:[UIColor purpleColor]];//设置navigationbar的颜色  
    8.     self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonItemStyleDone target:self action:Nil];//设置navigationbar左边按钮  
    9.     self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonItemStylePlain target:self action:Nil];//设置navigationbar右边按钮  
    10.     [self.navigationController.navigationBar setTintColor:[UIColor whiteColor]];//设置navigationbar上左右按钮字体颜色  
    11. }  


    效果图如下:

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

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


    效果如下:

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

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

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

    1. @interface SecondViewController : UIViewController  
    2. @property (copy,nonatomic) NSString *str;  
    3. @end  
    1. - (void)viewDidLoad  
    2. {  
    3.     [super viewDidLoad];  
    4.     // Do any additional setup after loading the view.  
    5.     self.title = @"second";  
    6.     UIButton *aBUTTON = [[UIButton alloc]initWithFrame:CGRectMake(30, 30, 50, 30)];  
    7.     [aBUTTON setTitle:_str forState:UIControlStateNormal];  
    8.     [aBUTTON addTarget:self action:@selector(clicked) forControlEvents:UIControlEventTouchUpInside];  
    9.     [self.view addSubview:aBUTTON];  
    10. }  


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

      

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


    下面,我们来运行一下:

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

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

    1. - (void)clicked{  
    2.     [self.navigationController popViewControllerAnimated:YES];  
    3. }  


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

    uinavigationcontroller的一些简单的属性就先说到这里,欢迎留言补充,谢谢。

  • 相关阅读:
    jQuery动态表格插件 AppendGrid
    JavaScript:用JS实现加载页面前弹出模态框
    JavaScript(select onchange)的网页跳转的简单实现
    jQuery DataTables的简单实现
    JavaScript 设计模式之命令模式
    JavaScript 设计模式之代理模式
    JavaScript 设计模式之工厂模式
    JavaScript 设计模式之建造者模式
    集群服务器消息通讯办法
    游戏服务器端开发的基本大纲
  • 原文地址:https://www.cnblogs.com/feiyu-mdm/p/5565543.html
Copyright © 2011-2022 走看看