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

时间:2021-08-09 09:46:30

1. storyBoard与xib

 1> 概述

  • iOS下可视化编程分为两种方式: xib 和 storyboard
  • 在使用 xib 和 storyboard 创建 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 创建视图控制器

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

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

 5> storyboard 侧重于页面控制

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

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

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

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

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

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

  注意: cell 不再需要注册。

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

2. 页面跳转

 1> storyboard 页面跳转分为两种

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

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

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

 2> 方式

  push : push出下一个界面.

  modal : 模态出下一个界面

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

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

3. segue

 1> 概述

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

  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 方法(界面跳转默认的执行方法), 自定义跳转效果

 #import "CustomSegue.h"
#import "LoginViewController.h"
#import "CustomViewController.h" @implementation CustomSegue // 重写系统方法,页面跳转会走这个方法
- (void)perform { // 1. 获取源控制器
LoginViewController *loginVC = self.sourceViewController;
// 2.获取目标控制器
CustomViewController *customVC = self.destinationViewController; // 3.自定义页面切换效果
[UIView transitionFromView:loginVC.view toView:customVC.view duration: options:UIViewAnimationOptionTransitionCurlUp completion:^(BOOL finished) { // 动画完成后的操作
[loginVC.navigationController pushViewController:customVC animated:NO]; }]; } @end

 3> 界面传值

  storyboard界面间跳转会执行

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

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

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

4. sizeClasses屏幕适配

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

 sizeClasses 可以根据不同的选择,筛选出不同的布局情况来绘制 UI iOS学习33之可视化编程-StoryBoard

 设备对应关系如下:

  • 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)

iOS学习33之可视化编程-StoryBoard的更多相关文章

  1. iOS学习之UI可视化编程-StoryBoard

    一.StoryBoard与xib 对比: 相同点:都属于IB编程的方式,可以快速构建GUI. 不同点:xib侧重于单文件(单独的控制器或者视图)编辑,storyboard侧重于多页面关联.storyb ...

  2. iOS学习之UI可视化编程-XIB

    一.Interface Builder可视化编程 1.Interface Builder简介: GUI:图形用户界面(Graphical User Interface,简称GUI,又称图形用户接口)是 ...

  3. iOS开发UIKit框架-可视化编程-XIB

    1. Interface Builder 可视化编程 1> 概述 GUI : 图形用户界面(Graphical User Interface, 简称GUI, 又称图形化界面) 是指采用图形方式显 ...

  4. Java学习疑惑&lpar;8&rpar;----可视化编程&comma; 对Java中事件驱动模型的理解

    我们编写程序就是为了方便用户使用, 我觉得UI设计的核心就是简洁, 操作过于繁琐的程序让很大一部分用户敬而远之. 即使功能强大, 但是人们更愿意使用易于操作的软件. 近年流行起来的操作手势和逐渐趋于成 ...

  5. IOS学习笔记之 Socket 编程

    最近开始静心学习IOS编程,虽然起步有点晚,但有句话说的好:“如果想去做,任何时候都不晚”.所以在今天,开始好好学习IOS.(本人之前4年都是搞.Net的,java也培训过一年) 打算学IOS,从哪入 ...

  6. iOS学习之移除Main&period;storyboard

    每次使用Single View Application模板创建工程之后,总是会有一个Main.storyboard文件,那么,当我们使用代码布局的时候,很显然是不需要它的.那么,如何将它从工程中移除呢 ...

  7. HNU&lowbar;小中初数学学习软件(可视化编程)&lowbar;结对项目总结与体会

    前言 经过将近一周的共同努力,HnuLyx和我终于完成了项目,期间心酸苦辣,受益良多,请允许我一一道来. 问题(需求要求的

  8. 【原】iOS学习之UIStoryboardSegue解析

    在 Storyboard 的可视化编程中,跳转界面就是按住 Ctrl 使用鼠标头一条连线就可以解决,相当的简单!本篇博客主要就是介绍这条连线,在iOS中,这条连线也是一个对象,也有其自己的初始化方法和 ...

  9. iOS学习之flappyBird游戏的实现

    导言 在本人还是学生的时候,flappyBird这款游戏非常火爆,最后等到Android版的出来之后,也是很痴迷的玩了一把.可是,本人游戏天赋一直平平,几度玩得想摔手机.本文主要介绍如何开发iOS平台 ...

随机推荐

  1. form表单提交路径action&equals;&quot&semi;&quot&semi; 时的一种特殊情况

    一.说明: 当页面的form表达的action=""时,表示表单会提交到当前页面,但是如果当前页面的URL里已经带有一个参数了,每次提交表达时这个参数依然存在,不管form表单里有 ...

  2. 使用lsof查看进程句柄使用情况

    lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr|more

  3. Python的with语句

    写过多线程程序的人肯定对各种锁很熟悉,尤其是下面这种代码 def lock_usage: lock.Lock() if(...) : lock.Unlock() return lock.Unlock( ...

  4. 常用HTML meta 标签属性&lpar;网站兼容与优化需要&rpar;,meta标签

    常用HTML meta 标签属性(网站兼容与优化需要),meta标签 标签提供关于HTML文档的元数据.元数据不会显示在页面上,但是对于机器是可读的.它可用于浏览器(如何显示内容或重新加载页面),搜索 ...

  5. js 中&amp&semi;&amp&semi; 与 &vert;&vert;

    /*** 几乎所有语言中||和&&都遵循“短路”原理,* 如&&中第一个表达式为假就不会去处理第二个表达式,而||正好相反.* js也遵循上述原则.* 当||时,找到为 ...

  6. ManagedPipelineHandler IIS

    IIS上部署MVC网站,打开后500错误:处理程序“ExtensionlessUrlHandler-Integrated-4.0”在其模块列表中有一个错误模块“ManagedPipelineHandl ...

  7. shell中的退出状态码

    shell中的退出状态码最大只有255,如果超过这个值,就会进行取余运算,即如果执行如下命令: exit exitCode 如果exitCode大于255,那么实际的状态码为exitCode % 25 ...

  8. 维吉尼亚密码java代码实现根据密钥长度计算IC值过程

    package cn.longxuzi; import java.util.Scanner; import org.junit.Test; public class ICUtils { /** * @ ...

  9. &lbrack;Mysql&rsqb; 安装后启动不了

    Mysql安装后启动报错: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql ...

  10. iOS 8 中如何集成 Touch ID 功能

    2013年9月,苹果为当时发布的最新iPhone产品配备了一系列硬件升级方案.在iPhone 5s当中,最具创新特性的机制无疑要数围绕Home按钮设计的超薄金属圈,也就是被称为Touch ID的指纹传 ...