继第一篇storyboard新手教程:http://blog.csdn.net/u013582514/article/details/49977059

继续讲解

3.添加约束(important)

选中item1 这是一个普通的vc拖一个按钮button上去

此时button是被选中状态,哪个控件是被选中状态就为哪个控件添加约束

视角转到中间底部偏右 wAny hAny右边

点击第二个按钮

其中上面灰色的约束是啥我不太清楚(不常用)最后两个约束的意思是如果值为0就垂直居中或者水平居中,左边的选择框选中后再点击下面的Add Constraints按钮

(灰色说明没有约束被选中)即可添加

此时注意 添加约束时如果约束没有添加完全则会报错(比如你只添加了距离左边边距约束则会报错,不同的控件 “约束添加完成”条件不同)

再来看第三个按钮的约束(简单约束核心内容)

首选取消Constrain to margins的选中状态

Constrain to margins的意思就是苹果官方默认为你准备的边距效果 他们认为距离8是不错的距离

所以如果你选中了Constrain to margins 设置边距为0后实际上是8(真是毫无意义的设定……)

取消选中后看上面实际上有四个约束

这四个约束分别就是距离上下左右最近的控件的距离 目前这个button的在vc的view上面 view上面也只有这一个button 所以这四个约束代表该button距离他的superview四个边距的距离 但都没哪一个约束是准备添加状态

此时已准备好添加两个约束(点一下红线就更改是否添加状态)它们分别是上边距和左边距

此时往下点击Add 3 Constraints按钮添加三个约束

发现界面上只有黄线而没有红线 这说明已满足约束完全条件(button的条件很随意 只要左边距和上边距即可满足)三根黄线代表了它的实际样子需要更新 视角转到左边

发现有一个小黄色按钮点击它

之后点击黄色三角

发现有很多选择 一般是选择Update frames更新该控件的frame

该按钮的意思是为所有控件都执行此方法进行修改 目前只有一个button 无需选中

点击按钮后 选中界面上的button

我们可以看到该button的长度是屏幕长度 而高度因为没有约束所以是按照字体大小来自适应的(如果没有左边距或右边距则长度会根据文字数量自适应)

接下来看下面的约束

一看就能明白 这是设置该按钮的固定长度和高度(注意此时设置width是不赞成的 如果设置为320可以编译通过 但是在iPhone6上因为屏幕尺寸长度不是320则会出问题,如果设置的数值不是320会报错),此时设置固定高度为40 选中左边选择框 之后点击下方添加约束按钮(这里就不配图了)

可以发现多了一根黄线 数值是-10 意思就是该按钮高度与实际高度相比-10

再看下面的约束

最后一个约束Align没用过……

看Aspect Ratio约束 意思就是该控件的长宽比

添加该约束 之后视角转到右上角

可以发现你自己已经添加的约束

总共是五个约束 其中是宽高比约束 点击右边的edit

第一个constant对于该约束没有实际意义(它的数值可以代表边距的距离数值)

第二个Priority代表优先值 默认都是1000 意思是先满足哪个约束要求 当你设置多个同类约束时设置好优先值就不会报错 同时会按照优先顺序满足你设置的约束条件

第三个multiplier就是该约束很重要的属性了 可以看到该按钮长宽是40和320 所以添加宽高比约束时默认是320:40也就是8:1 修改它可以更改宽高比(但是此时更改后会报错,因为你同时设置了左、右边距固定了长度 以及固定高度 所以你的宽高此时实际上是固定的,只不过该约束满足了其它约束条件所以没有报错,简而言之它们目前是同类约束)。

双击一个约束后会选中该约束,再按中键盘上的delete按钮即可删除该约束。

目前还剩下最后两个约束

这两个约束需要你同时选中两个控件,先在再添加一个button

删掉第一个button的宽高比和固定高度约束

为第二个按钮添加上下左右边距约束

添加完成后我们可以发现 报错了~ 这是因为此时编译器并不知道该如何为这两个按钮配置高度 因为虽然有根据字体自适应 但是因为你为第二个按钮设置了上边距 也就是两个按钮上下距离为0 那么他们的高度该如何确定?第一个自适应 第二个拉长?第二个自适应 第一个拉长?这是有歧义的

我们只需要添加一个equal heights约束就好了

先选中两个按钮

还可以看左边来确定是不是都选中了

如果两个button背景都变灰就是都选中了

添加完成后就不会报错了 更新一下frame

可以发现两个按钮高度相同

此时基本约束就讲解完成了

如果没看懂 就再看一遍 如果还没看懂 那简直连诚哥都不如~23333

storyboard(故事版)新手教程 图文详解 2.为无约束的故事版添加约束相关推荐

  1. storyboard(故事版)新手教程 图文详解 3.在故事版上使用scrollview

    继上一篇内容storyboard(故事版)新手教程 图文详解 2.为无约束的故事版添加约束 选中item2 此时上面什么都没有 添加一个scrollview 添加上下左右边距都为零 更新frame(不 ...

  2. storyboard(故事版)新手教程 图文详解 1.创建一个无约束的导航栏加选项卡(tabbar)故事版

    OSX系统10.10.5 Xcode版本7.1 本文图文详解如何初步使用故事版进行开发 1.打开Xcode  点击Create a new Xcode project 选择Single View Ap ...

  3. storyboard(故事版)新手教程 图文详解 4.把约束拉成属性 在代码文件里进行修改

    继上一篇内容http://blog.csdn.net/u013582514/article/details/49977437 上一篇文章中我们讲述了怎么使用scrollview在故事版中设置它的相关滑 ...

  4. win mysql5.7 msi_win10 安装 mysql 5.7 msi版的教程图文详解

    我装msi格式的,主要是想看看装完的my.ini, 文件位置C:\ProgramData\MySQL\MySQL Server 5.7\my.ini, 注意:ProgramData是隐藏文件夹 mys ...

  5. MySQL Installer 8.0.21安装教程图文详解 转载

    MySQL Installer 8.0.21安装教程图文详解 原地址 1. 缘由 刚好需要在新系统上重新安装MySQL,便写了一份的下载安装教程,供查阅,以防日后细节有所遗忘. 2. 版本说明 MyS ...

  6. mysql installer安装_MySQL Installer 8.0.21安装教程图文详解

    1. 缘由 刚好需要在新系统上重新安装MySQL,便写了一份的下载安装教程,供查阅,以防日后细节有所遗忘. 2. 版本说明 MySQL Installer 8.0.21 3. 下载安装包 方式一:官网 ...

  7. python3.6安装教程-python3.6环境安装+pip环境配置教程图文详解

    1.python安装可以跨平台 2.有两个版本2.7和3.6,第三方库适用2.7版,两个版本不兼容 windows安装: 第一种方法官网安装: 在官网下载安装包如图: 图下点击是默认下载32位所以我们 ...

  8. python详细安装教程环境配置-python3.6环境安装+pip环境配置教程图文详解

    1.python安装可以跨平台 2.有两个版本2.7和3.6,第三方库适用2.7版,两个版本不兼容 windows安装: 第一种方法官网安装: 在官网下载安装包如图: 图下点击是默认下载32位所以我们 ...

  9. python3.6.0怎么安装pip_python3.6环境安装+pip环境配置教程图文详解

    1.python安装可以跨平台 2.有两个版本2.7和3.6,第三方库适用2.7版,两个版本不兼容 windows安装: 第一种方法官网安装: 在官网下载安装包如图: 图下点击是默认下载32位所以我们 ...

最新文章

  1. 解决nodejs环境下端口号被占用的方法
  2. 高效的CSS(2008年7月4日更新)
  3. oracle查看数据库名和实例名
  4. curl和wget的区别和使用
  5. Nginx的http块自定义服务日志
  6. IDEA系列(四)一部署war 和 war exploded的区别
  7. 计算机的四个硬盘有什么区别是什么意思,笔记本的内存和硬盘有什么区别 原来笔记本硬盘有这几种...
  8. 【kafka】kafka单节点测试
  9. java server.xml_tomcat配置文件server.xml详解
  10. @贾跃亭,证监会喊你本周回国对乐视负责!
  11. 产品迭代发布如何更快速?阿里持续集成与持续交付实践之路全解析
  12. JAVA调用百度OCR实现身份证识别
  13. ztree 使用教程
  14. 车联网在智慧城市中的发展与应用
  15. Python面向对象加强2.Python 中类的内置属性和内置方法(魔法函数)
  16. Array Shrinking
  17. 学并发编程,透彻理解这三个核心是关键
  18. 关于荧光染料(FITC、RB罗丹明、Cy3,Cy3.5,Cy5,Cy5.5,Cy7,Cy7.5)
  19. 什么是同类群组联合学习 (FLoC)?
  20. 技术状态管理(六)-技术状态审核

热门文章

  1. 强化学习笔记3-Python/OpenAI/TensorFlow/ROS-规划博弈
  2. 微信小程序商城开发-商品详情页跳转购物车
  3. 【干货】一文详解计算机视觉的广泛应用:网络压缩、视觉问答、可视化、风格迁移等
  4. mmkv原理,Android多进程从头讲到尾,成功定级腾讯T3-2
  5. 【云原生】AI云开发平台——AI Model Foundry介绍(开发者可免费体验AI训练模型)
  6. 【练习】Accessing data with MySQL
  7. 机器学习环境配置(Tesla K80安装PyTorch的全过程)
  8. 新版HyperMesh的Assemblies中调出下拉菜单查看Component(装配关系模型树)
  9. 基于视频分析的rPPG心率检测
  10. Androi--内容提供器