故事板(UIStoryboard)可以很方便的进行界面的设计,下面总结了常用的几个操作方法:
1,初始场景
选中View Controller,在属性面板里勾选Is Initial View Controller复选框,即可设置为起始场景(前面会显示灰色的小箭头)
2,将View Controller的尺寸改成iPhone大小
(1)点击左侧的Main.storyboard。然后选择右侧的 show the File inspector(纸张图标),最后将Use Size Classes前面的勾去掉。
(2)在弹出的窗口中,选择iPhone为Keep size class data 的值。然后点击Disable Size Class按钮即可。
(3)此时Xcode中间的布局样式看上去就像个iPhone的样子了。
![](http://www.hangge.com/blog_uploads/201504/2015041414293111559.png)
![](http://www.hangge.com/blog_uploads/201504/2015041414294565570.png)
3,添加segue
使用seque的好处是,页面的切换不再需要创建任何代码。按住Ctrl键同时拖动控件到目标场景,在弹出的上下文菜单中选择show。
(1)菜单中中间4个是过去版本的使用方式,推荐最上面的4个新的方式:
Show:就是Push一个新的视图
Show Detail:替换当前的视图方式来展现新的视图
Modally:模式窗口的方式
Popover:浮窗形式
(2)如果是两个Controller之间建立包含关联,例如从TableBarController到NavigationController,则上下文菜单会有relationship的选项,选择view controllers即可
4,给segue添加关联类
在stroyboard中添加一个seque时并不会同步添加对应的类。如果需要,我们要手动先创建一个swift类,比如叫MyView1。然后进入storyboard,选中对应的segue。在属性面板中设置对应的Class,如下图:
![](http://www.hangge.com/blog_uploads/201503/2015031016352810825.png)
5,添加代码关联
打开Assistant Editor同时显示界面设计与代码,按住Ctrl键同时拖动控件到代码,在弹出的上下文菜单中设置需要关联的类型,即可在代码里自动生成代码。
这里主要有两种关联类型,一种是Outlet连接,就是在代码里创建界面元素的成员变量引用。另一种是Action事件,把界面元素的响应事件方法添加到代码里来。(如果已经创建了代码,也可以把控件直接拖放到对应代码上,这时候就不是插入而是直接建立连接了)
6,同一个storyboard里多个View Controller的引用
如果要在代码里调用storyboard里的View Controller,可以设置View
Controller的identity。设置方法是,在stroyboard中选中View
Controller,在右侧的identity属性面板里设置StroyboardID。
比如设置类Main.storyboard里初始View Controller的identity为RootView,则通过以下方式引用:
1
2
|
var rootViewController = UIStoryboard(name: "Main" , bundle: nil) .instantiateViewControllerWithIdentifier( "RootView" ) as UIViewController |
对于初始View Controller也可以不通过identity直接获取:
1
2
|
var rootViewController = UIStoryboard (name: "Main" , bundle: nil ) .instantiateInitialViewController() as UIViewController |
7,使用多个storyboard文件
一个项目可以不止一个storyboard文件,它们间也可以互相调用。假如还添加一个Second.storyboard,里面的View
Controller设置identity为SecondView,则我们可以通过导航的方式来关联两个storyboard文件。
在AppDelegate的Application入口里把Main面板放入导航控制:
1
2
3
|
var rootViewController = UIStoryboard (name: "Main" , bundle: nil ) .instantiateInitialViewController() as UIViewController self .window!.rootViewController = UINavigationController (rootViewController: rootViewController) |
然后可以在RootView里放入一个按钮,点击事件里导航到Second面板:
1
2
3
|
var viewController = UIStoryboard (name: "Second" , bundle: nil ) .instantiateViewControllerWithIdentifier( "SecondView" ) as UIViewController self .navigationController?.pushViewController(viewController, animated: true ) |