Storyboard是IOS5以后新增的内容,从名字上看,是以故事面板的形式来展现界面间的逻辑关系,Storyboard的功能很强大,今天就简要介绍Storyboard的基本使用,界面间的关系,以及如何使用xib和Storyboard共同使用的情况。

首先新建一个Empty工程,并新建一个Storyboard,我命名为MainStoryboard,以下是完整的工程目录结构:

打开MainStoryboard后拖入一个UITabViewController,并设置两个tab为UINavigationController,第三个tab设置一个ViewController。关联的方式为按住control点击鼠标左键拖动到目标界面即可,松开鼠标后点击如下第一个选项:

最后在UINavigationController上分别添加Next按钮,同样按住control键点击拖动到下一个界面松开选择push就完成了跳到下一页的功能,这比之间在代码中手写要方便、快捷。第一个Storyboard的整体布局如下:

在最后一个ViewController中(Third)中添加按钮,点击后跳到另外一个Storyboard(SecondStoryboard),SecondStoryboard的布局如下:

同样给SecondStoryboard添加一个导航视图。

然后新建几个ViewController文件,分别命名为FirstViewController、SecondViewController。。。,并在storyboard中选中指定的界面关联这些ViewController文件:

接下来就是主要实现的代码,在AppDel额gate中添加如下代码:

[cpp] view http://blog.csdn.net/ryantang03/article/details/7919234
  1. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
  2. {
  3. self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
  4. // Override point for customization after application launch.
  5. //使用Storyboard初始化根界面
  6. //    UIStoryboard *storyBoard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  7. //    self.window.rootViewController = [storyBoard instantiateInitialViewController];
  8. //启动后首先进入登陆界面
  9. LoginViewController *loginViewController = [[LoginViewController alloc] initWithNibName:@"LoginViewController" bundle:nil];
  10. self.window.rootViewController = loginViewController;
  11. self.window.backgroundColor = [UIColor whiteColor];
  12. [self.window makeKeyAndVisible];
  13. return YES;
  14. }

现在编译运行后,就可以看到界面了:

然后打开ThirdViewController,为按钮添加如下事件,切换到SecondStoryboard

[cpp] view plaincopy
  1. - (IBAction)openStoryboard:(id)sender {
  2. UIStoryboard *secondStoryboard = [UIStoryboard storyboardWithName:@"SecondStoryboard" bundle:nil];
  3. [self presentModalViewController:[secondStoryboard instantiateInitialViewController] animated:YES];
  4. }

这样就完成了从一个storyboard切换到另一个storyboard。

运行截图如下:

    

接下来实现如何结合xib和storyboard共同使用,在一般开发中有这么一种场景,首先打开软件后进入登陆或者注册界面,登陆成功后跳转到软件首页,那么这里建立一个LoginViewController并创建LoginViewController.xib文件,里面添加一个Login按钮,并响应事件:

[cpp] view plaincopy
  1. <span style="font-family:Comic Sans MS;font-size:18px;">- (IBAction)loginBtnClicked:(id)sender {
  2. //点击登陆按钮后切换到storyboard界面
  3. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  4. //    self.view.window.rootViewController = [storyboard instantiateInitialViewController];
  5. [self presentModalViewController:[storyboard instantiateInitialViewController] animated:YES];
  6. [storyboard release];
  7. }</span>

点击Login按钮后,就跳转到之前实现Storyboard的首页了:

转自http://blog.csdn.net/ryantang03/article/details/7919234;

源码下载

转载于:https://www.cnblogs.com/flylovesky/p/3310691.html

OS学习笔记32—使用Storyboard实现复杂界面相关推荐

  1. 【OS学习笔记】四十 保护模式十:中断和异常的处理与抢占式多任务对应的汇编代码----动态加载的用户程序/任务二代码

    本文是以下几篇文章对应的微型动态加载的用户程序/任务二代码: [OS学习笔记]三十四 保护模式十:中断和异常区别 [OS学习笔记]三十五 保护模式十:中断描述符表.中断门和陷阱门 [OS学习笔记]三十 ...

  2. 【OS学习笔记】三十九 保护模式十:中断和异常的处理与抢占式多任务对应的汇编代码----动态加载的用户程序/任务一代码

    本文是以下几篇文章对应的动态加载的用户程序/任务一代码: [OS学习笔记]三十四 保护模式十:中断和异常区别 [OS学习笔记]三十五 保护模式十:中断描述符表.中断门和陷阱门 [OS学习笔记]三十六 ...

  3. 【OS学习笔记】三十八 保护模式十:中断和异常的处理与抢占式多任务对应的汇编代码----微型内核汇代码

    本文是以下几篇文章对应的微型内核代码汇编代码: [OS学习笔记]三十四 保护模式十:中断和异常区别 [OS学习笔记]三十五 保护模式十:中断描述符表.中断门和陷阱门 [OS学习笔记]三十六 保护模式十 ...

  4. 【OS学习笔记】三十七 保护模式十:中断和异常的处理与抢占式多任务对应的汇编代码----主引导扇区代码

    本文是以下几篇文章对应的主引导扇区代码汇编代码: [OS学习笔记]三十四 保护模式十:中断和异常区别 [OS学习笔记]三十五 保护模式十:中断描述符表.中断门和陷阱门 [OS学习笔记]三十六 保护模式 ...

  5. 【OS学习笔记】三十五 保护模式十:中断描述符表、中断门和陷阱门

    上一篇文章学习了中断与异常的概念:[OS学习笔记]三十四 保护模式十:中断和异常区别 本片文章接着学习以下内容: 中断描述符表 中断门 陷阱门 1 中断描述符表 我们前面讲了无数次,在实模式下,是由位 ...

  6. 【OS学习笔记】三十三 保护模式九:分页机制对应的汇编代码之---用户程序代码

    本片文章是以下两篇文章: [OS学习笔记]三十 保护模式九:段页式内存管理机制概述 [OS学习笔记]三十一 保护模式九:页目录.页表和页三者的关系详解 对应的用户程序汇编代码. ;代码清单16-2;文 ...

  7. 【OS学习笔记】三十二 保护模式九:分页机制对应的汇编代码之---内核代码

    本片文章是以下两篇文章: [OS学习笔记]三十 保护模式九:段页式内存管理机制概述 [OS学习笔记]三十一 保护模式九:页目录.页表和页三者的关系详解 对应的内核汇编代码. ;代码清单16-1;文件名 ...

  8. 【OS学习笔记】二十九 保护模式八:任务切换对应的汇编代码之用户程序代码

    本汇编代码对应以下两篇文章对应的用户程序汇编代码: [OS学习笔记]二十六 保护模式八:任务门-任务切换 [OS学习笔记]二十七 保护模式八:任务切换的方法之----jmp与call的区别以及任务的中 ...

  9. 【OS学习笔记】二十八 保护模式八:任务切换对应的汇编代码之内核代码

    本汇编代码对应以下两篇文章对应的内核汇编代码: OS学习笔记]二十六 保护模式八:任务门-任务切换 [OS学习笔记]二十七 保护模式八:任务切换的方法之----jmp与call的区别以及任务的中断嵌套 ...

最新文章

  1. github 与git 使用 及配置
  2. SwiftSuspenders 1.6 浅出深入 深入 2
  3. CentOS下安装protobuf
  4. VC基于MSCOMM控件串口通讯
  5. ifix从sqlserver里读数据_ifix连接SQL和读写EXCEL的方法
  6. 最大并发连接数和最大会话数的区别
  7. 内存溢出与内存泄漏区别
  8. 花书+吴恩达深度学习(十一)卷积神经网络 CNN 之池化层
  9. SSM整合配置文件总结
  10. Leetcode: One Edit Distance
  11. QT 自带字体样式有哪些?
  12. httprunner 2.x学习4-测试用例分层
  13. linux富文本软件,CherryTree(技术人员专用富文本笔记软件)
  14. UART 协议以及概念
  15. 在日软件工程师的远虑近忧
  16. PG创建临时表时添加on commit drop参数
  17. SpriteKit从零开始~Physics and Collisions
  18. python在线办公自动化oa系统django408
  19. 关于0.96 OLED显示屏显示数字
  20. 排班所需表结构--排班(二)

热门文章

  1. Eviews 9.0新功能——估计方法(ARDL、面板自回归、门限回归)
  2. lr中错误解决方法(收集)
  3. Django--CRM-客户列表展示, 分页
  4. Linux编辑启动停止重启springboot jar包脚本
  5. EF多对多关系中如何利用关系表(EF4.1 Many to Many involves junction table details)
  6. 多种问题袭来:崩溃在边缘的“直播赚钱路”
  7. Struts 2 的学习笔记(二) struts的配置流程和strut是2的工作原理
  8. 【Git入门之六】远程仓库
  9. FreeBSD学习笔记17-FreeBSD下安装MySQL数据库
  10. Google的Java常用类库 Guava