iOS学习33之可视化编程-StoryBoard

1. storyBoard与xib

 1> 概述

  • iOS下可视化编程分为两种方式: xibstoryboard
  • 在使用 xibstoryboard 创建 GUI 过程中,以 XML 文件格式存储在 Xcode 中,编译时生成 nib 的二进制文件. 在运行时, nib 文件被加载并且开始创建和实例化 GUI 元素

 2> 对比

  相同点:都属于 IB 编程的方式, 可以快速构建 GUI

  不同点:xib 侧重于单文件(单独的控制器或者视图)编辑, storyboard 侧重于多页面关联storyboard 可以直观梳理出页面间的逻辑, 并且所有页面跳转逻辑均可在 - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender 方法完成, 方便界面间数据统一管理

 3> storyboard 注意事项

  • AppDelegate-application: didFinishLaunchingWithOptions: 方法中不要再用代码初始化一个 Window
  • 将创建好的 storyboard 在应用程序配置 General 中设置为 Main Interface
  • 视图添加控制IB 开发 样。

 4> storyboard 创建视图控制器

  在 storyboardcontroller 可以设置标识, 通过标识在 storyboard 中创建视图控制器对象。

  [self.storyboard instantiateViewControllerWithIdentifier: @"identifier"];

 5> storyboard 侧重于页面控制

  使 storyboard 可以方便快捷的直接拖拽出一个视图控制器, 其中包括 View ControllerNavigation ControllerTable View  Controller 等等。

  我们可以通过选中控制器, 修改下图所示的选项, 或者直接移动表程序入口的箭头,来观察各控制器的效果

 6> 利用 storyboard 绘制自定义单元格

  storyboard 绘制单元格的时候要注意以下几点:

  • 创建自定义 cell 时选中左侧 TableViewCell
  • 绘制定义 UI 界面。
  • 设置重用标识符
  • storyboard 文件关联至对应的 UITableViewControllerUITableViewCell 类(自己创建的类)。
  • UITableViewController 中完成代码书写:设置 sectionrow 数量, 设置 cell , 根据实际情况调整 cell 的高度。

  注意: cell 不再需要注册。

2. 页面跳转

 1> storyboard 页面跳转分为两种

  ① 代码方式 : 使用代码通过控制器识别来跳转. 比如在当前页面的某一个事件中跳转到一个标识为 "customVC" 的控制器页面中: [self performSegueWithIdentifier:@"customVC" sender:nil];

  ② 连线方式 : 直接使用拖拽可以给按钮连线关联两个页面: 选中按钮, 按住 control ,从按钮向下一级页面连线. 按钮不需要添加响应方法.

 2> 方式

  push : push出下一个界面.

  modal : 模态出下一个界面

  custom : 自定义,需要我们自己实现页面跳转, 需要自定义segue.

  注意: 以上是 sizeclasses 未勾选的状态下的三种方式. 在默认状态下有很多种, 其中包括show, showDetail等等.

3. segue

 1> 概述

  segue: 可视化编程中连接两个页面的线条,称之为 segue.

  iPhoneGUI 开发中 segue 主要有三种类型, 包括 push, model, custom.

  其中 custom 需要我们自定义 segue 来完成页面间跳转.

  segue 有三个重要属性: 标识符, 源控制器, 目标控制器. 

 2> 自定义 segue

  步骤一: 新建一个类继承自 UIStoryboardSegue

#import <UIKit/UIKit.h>

@interface CustomSegue : UIStoryboardSegue

@end

  步骤二: 选中一个控制器,按住 control 鼠标辅助完成连线, 选择 custom

  步骤三: 选中自定义 segue, 设置 segue 的 identifier 以及关联类

  步骤四: 在 segue 类里面重写 perform 方法(界面跳转默认的执行方法), 自定义跳转效果

 1 #import "CustomSegue.h"
 2 #import "LoginViewController.h"
 3 #import "CustomViewController.h"
 4 
 5 @implementation CustomSegue
 6 
 7 // 重写系统方法,页面跳转会走这个方法
 8 - (void)perform {
 9    
10     // 1. 获取源控制器
11     LoginViewController *loginVC = self.sourceViewController;
12     // 2.获取目标控制器
13     CustomViewController *customVC = self.destinationViewController;
14     
15     // 3.自定义页面切换效果
16     [UIView transitionFromView:loginVC.view toView:customVC.view duration:2 options:UIViewAnimationOptionTransitionCurlUp completion:^(BOOL finished) {
17         
18         // 动画完成后的操作
19         [loginVC.navigationController pushViewController:customVC animated:NO];
20         
21     }];
22     
23 }
24 
25 @end

 3> 界面传值

  storyboard界面间跳转会执行

  - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender 方法, 方便界面间数据统一管理.

  依据不同的标识符来完成数据处理. 

 1 // storyboard页面跳转会走这个方法
 2 - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
 3    
 4     if ([segue.identifier isEqualToString:@"welcome"]) {
 5         
 6         // 属性传值(从前往后传)
 7         // 获取到要跳转的控制器对象
 8         WelcomeViewController *welcomeVC = segue.destinationViewController;
 9         // 2.设置属性 
10         welcomeVC.textString = self.userTextField.text;
11 12     }
13 } 

4. sizeClasses屏幕适配 

 在实际开发当中程序员不可能只考虑一种尺寸, 有时需要做必要的屏幕适配工作, 甚至还会遇到横竖屏时不同的布局方式, 在可视化编程中, sizeClasses 就是因此而诞生的.

 sizeClasses 可以根据不同的选择,筛选出不同的布局情况来绘制 UI 

 设备对应关系如下:

  • iPhone4S, iPhone5/5S, iPhone6, iPhone6s

   竖屏: (w:Compact h:Regular)

   横屏: (w:Compact h:Compact)

  • iPhone6 Plus/iPhone6s Plus

   竖屏: (w:Compact h:Regular)

   横屏: (w:Regular h:Compact)

  • iPad

   竖屏: (w:Regular h:Regular)

   横屏: (w:Regular h:Regular)

 

posted @ 2016-04-26 20:35  墨隐于非  阅读(737)  评论(0编辑  收藏  举报