一、Interface Builder可视化编程

  1、Interface Builder简介:

  • GUI:图形用户界面(Graphical User Interface,简称GUI,又称图形用户接口)是指采用图形方式显示的计算机操作用户界面。
  • Interface Builder(IB):是Mac OS X 平台下用于设计和测试图形用户界面的应用程序。代码和IB都可以生成GUI。
  • 优势:IB能够使开发者简单快捷的开发出符合Mac系列操作系统的GUI。通常只需要通过简单的拖拽操作来构建GUI。IB使用Nib文件储存GUI资源,在需要的时候,Nib文件可以被快速的载入内存。

  2、iOS可视化编程

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

二、xib简单实用

  1、.xib创建

  • xib通常以关联方式出现在工程文件中,即在被创建时是伴随一个类(UIKIT框架下的类)诞生的。如图所示:
  • 关联xib后,视图控制器独有的初始化方法:
    // 创建视图控制器,给window指定根控制器
    // 程序编译时会将xib文件编译成nib的二进制文件,运行时加载nib文件
    // nibName:当前控制器相关联的nib文件,如果写为nil,默认查找和控制器名相同的文件名,但是如果xib文件与控制器名不相同,则查找不到。
    // bundle:获取程序的资源路径,如果写为nil,默认是主路径,因为iOS只有一个主路径,在mac端开发时必须写。
    self.window.rootViewController = [[RootViewController alloc] initWithNibName:@"RootViewController" bundle:[NSBundle mainBundle]];
  • 创建好后.xib文件的样式

  2、控件关联

  • 在可视化编程中,功能部分仍然需要依赖于代码,所以我们需要将控件和代码相关联起来。
  • 插座变量:用于IB中的UI控件。
  • IBOutlet:外联指针,连接插座变量和IB中的UI空间。
  • 设置:选中控件,按住control,向接口部分中拖拽,即可关联。
  1. Connection:拖拽之后创建的类型(属性、方法、集合属性)。
  2. Object:绑定的对象。
  3. Name:方法名或者属性名字。
  4. Type:控件类型。
  5. Storage:控件的内存修饰参数。

  3、事件关联

  • 动作:用于响应UI控件的触发事件。IBAction,连接方法和IB中的UI控件。
  • 设置:选中控件,按住control,向原类接口部分或者实现部分中拖拽,设置响应方法。
  1. Name:方法名。
  2. Type:方法中的参数类型。
  3. Event:触发方法的方式。
  4. Arguments:方法中携带的什么样的参数。

  4、代理设置

  • File's owner:文件的拥有者,即视图控制器。
  • 设置:右键单击控件,连接代理变量和File's owner。

三、xib绘制单元格

  1、自定义单元格

  • 自定义单元格指的是UITableView的自定义cell。
  • 通过xib可以快速的绘制cell。
  • 新建UITableViewController子类,设置为根视图控制器。
  • 新建一个UItableViewCell子类,勾选Also create XIB file。
  • 设置cell的重用标识符
    // 注册cell
    [self.tableView registerNib:[UINib nibWithNibName:@"CustomCell" bundle:[NSBundle mainBundle]] forCellReuseIdentifier:identifier_cell];
    // 返回cell
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    CustomCell *cell = [tableView dequeueReusableCellWithIdentifier:identifier_cell forIndexPath:indexPath];
    return cell;
}

四、自动布局

  1、自动布局

  • 自动布局:autoLayout,不给View固定的位置,通过某些规则让View自己适应自己的位置。
  • 自动布局中常用的四个选项

  2、Stack

  • UIStackView,可以管理多个视图。一次性为多个视图进行约束设置。
  • Axis:子视图排布方向。
  • Alignment:子视图对齐方式。
  • Distribution:分布方式。(调整StackView的大小,切换选项观察)。
  • Space:子视图的最小间距。

  3、Align

  • Align,设置视图的对齐方式。
  • Leading Edges:左对齐。
  • Trailing Edges:右对齐。
  • Top Edges:上对齐。
  • Bottom Edges:下对齐。
  • Horizontal Centers:纵向中心对齐。
  • Vertical Centers:横向中心对齐。
  • BaseLines:基线对齐。
  • Horizontally in Container:以屏幕的纵向中心线对齐。
  • Vertically in Container:以屏幕的横向中心对齐。
  • 两者结合使用可以让View的中心点和屏幕中心点对齐。

  4、Pin

  • Pin:设置视图的尺寸相关属性。
  • 上面的四个方向的设置尺寸代表距离四个方向的最近的视图的距离。
  • 如果对应方向没有视图,则视为对应的屏幕方向的距离。
  • Constrain to margins选项表示是否留下20个点的位置。
  • Width:视图的宽度。
  • Height:视图的高度。
  • AspectRatio:设置宽高比。
  • 当选中一个以上的视图个数:
  • Equal Width:两个视图等宽。
  • Equal Height:两个视图等高。

  5、Resolve Auto Layout Issues

  • Resolve Auto Layout Issues:解决自动布局的问题。
  • Selected Views:选中的View,不包含子视图。
  • All Views in View:选中的View,包含子视图。
  • Update Frames:更新位置信息。
  • Update Constraints:更新约束信息。
  • Add Missing Constraints:忽略约束不足的错误。
  • Reset to Suggersted Constraints:重置被建议的约束。
  • Clear Constraints:删除所有的约束。

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

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

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

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

    1. storyBoard与xib 1> 概述 iOS下可视化编程分为两种方式: xib 和 storyboard 在使用 xib 和 storyboard 创建 GUI 过程中,以 XML 文 ...

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

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

  4. iOS学习32之UIKit框架-可视化编程-XIB

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

  5. Java学习疑惑(8)----可视化编程, 对Java中事件驱动模型的理解

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

  6. IOS学习笔记之 Socket 编程

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

  7. iOS学习之UI自定义cell

    一.自定义Cell 为什么需要自定义cell:系统提供的cell满足不了复杂的样式,因此:自定义Cell和自定义视图一样,自己创建一种符合我们需求的Cell并使用这个Cell.如下图所示的这些Cell ...

  8. HNU_小中初数学学习软件(可视化编程)_结对项目总结与体会

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

  9. ios可视化编程 UI高级 UI_13

    一.简单的说,IB Xib就是拖控件编程,也可以说是可视化编程(所见即所得),使用Xib编程,相对于纯代码,可以省下大量的敲代码时间,从而提高程序的开发时间,Xcode  4 之后才可以在工程中直接使 ...

随机推荐

  1. ASP.NET运行机制原理 ---浏览器与IIS的交互过程 自己学习 网上查了下别人写的总结的很好 就转过来了 和自己写的还好里嘻嘻

    一.浏览器和服务器的交互原理 (一).浏览器和服务器交互的简单描述: 1.通俗描述:我们平时通过浏览器来访问网站,其实就相当于你通过浏览器去访问一台电脑上访问文件一样,只不过浏览器的访问请求是由被访问 ...

  2. 【Struts 1】Struts1的基本原理和简介

    备注:这里介绍的是Struts1的内容,Struts2的内容,会在后续的博客的予以说明! 一.什么是Struts struts的目标是提供一个开发web应用的开源框架,Struts鼓励基于Model2 ...

  3. JS常用的设计模式(17)—— 状态模式

    状态模式主要可以用于这种场景 1 一个对象的行为取决于它的状态 2 一个操作中含有庞大的条件分支语句 回想下街头霸王的游戏. 隆有走动,攻击,防御,跌倒,跳跃等等多种状态,而这些状态之间既有联系又互相 ...

  4. oracle 强杀进程

    在ORACLE数据库当中,有时候会使用ALTER SYSTEM KILL SESSION 'sid,serial#'杀掉一个会话进程,但是使用这个SQL语句杀掉会话后,数据库并不会立即释放掉相关的资源 ...

  5. 必须会的SQL语句(五)NULL数据处理和类型转换

    1.Null数据的处理     1)检索出null值               select * from 表 where xx is null        2)null值替换      sele ...

  6. 使用eclipse与jLink V8调试exynos 4412 u-boot

    /** ****************************************************************************** * @author    Maox ...

  7. puppet实现主从部署各种软件实战参考模型

    puppet实现主从部署各种软件实战参考模型   实验要求:     1.我将准备三个节点 node2 , node3 , node4 2.我们想让节点node3部署ntp,nginx ;节点node ...

  8. 如何在某个按钮上触发 bootstarp Modal 组件

    <?php Modal::begin([ 'id'=>'myModal', 'header' => '<h2>标题</h2>']); echo '内容'; M ...

  9. 【转】java 访问.net webservice返回的数据集

    转自[转的也是转的][http://blog.csdn.net/fox123871/article/details/8637839] 1. 概述 很多正在开发或者打算开发XML Web Service ...

  10. [leetcode]_Longest Substring Without Repeating Characters

    问题:求一个字符串中最长不重复子串的长度. 直接思路:以每个字符为出发计算最长不重复子串.TLE.O(n2),HashMap存储字符出现的位置. 代码: public int lengthOfLong ...