storyboard(故事版)新手教程 图文详解 2.为无约束的故事版添加约束
继第一篇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.为无约束的故事版添加约束相关推荐
- storyboard(故事版)新手教程 图文详解 3.在故事版上使用scrollview
继上一篇内容storyboard(故事版)新手教程 图文详解 2.为无约束的故事版添加约束 选中item2 此时上面什么都没有 添加一个scrollview 添加上下左右边距都为零 更新frame(不 ...
- storyboard(故事版)新手教程 图文详解 1.创建一个无约束的导航栏加选项卡(tabbar)故事版
OSX系统10.10.5 Xcode版本7.1 本文图文详解如何初步使用故事版进行开发 1.打开Xcode 点击Create a new Xcode project 选择Single View Ap ...
- storyboard(故事版)新手教程 图文详解 4.把约束拉成属性 在代码文件里进行修改
继上一篇内容http://blog.csdn.net/u013582514/article/details/49977437 上一篇文章中我们讲述了怎么使用scrollview在故事版中设置它的相关滑 ...
- win mysql5.7 msi_win10 安装 mysql 5.7 msi版的教程图文详解
我装msi格式的,主要是想看看装完的my.ini, 文件位置C:\ProgramData\MySQL\MySQL Server 5.7\my.ini, 注意:ProgramData是隐藏文件夹 mys ...
- MySQL Installer 8.0.21安装教程图文详解 转载
MySQL Installer 8.0.21安装教程图文详解 原地址 1. 缘由 刚好需要在新系统上重新安装MySQL,便写了一份的下载安装教程,供查阅,以防日后细节有所遗忘. 2. 版本说明 MyS ...
- mysql installer安装_MySQL Installer 8.0.21安装教程图文详解
1. 缘由 刚好需要在新系统上重新安装MySQL,便写了一份的下载安装教程,供查阅,以防日后细节有所遗忘. 2. 版本说明 MySQL Installer 8.0.21 3. 下载安装包 方式一:官网 ...
- python3.6安装教程-python3.6环境安装+pip环境配置教程图文详解
1.python安装可以跨平台 2.有两个版本2.7和3.6,第三方库适用2.7版,两个版本不兼容 windows安装: 第一种方法官网安装: 在官网下载安装包如图: 图下点击是默认下载32位所以我们 ...
- python详细安装教程环境配置-python3.6环境安装+pip环境配置教程图文详解
1.python安装可以跨平台 2.有两个版本2.7和3.6,第三方库适用2.7版,两个版本不兼容 windows安装: 第一种方法官网安装: 在官网下载安装包如图: 图下点击是默认下载32位所以我们 ...
- python3.6.0怎么安装pip_python3.6环境安装+pip环境配置教程图文详解
1.python安装可以跨平台 2.有两个版本2.7和3.6,第三方库适用2.7版,两个版本不兼容 windows安装: 第一种方法官网安装: 在官网下载安装包如图: 图下点击是默认下载32位所以我们 ...
最新文章
- 解决nodejs环境下端口号被占用的方法
- 高效的CSS(2008年7月4日更新)
- oracle查看数据库名和实例名
- curl和wget的区别和使用
- Nginx的http块自定义服务日志
- IDEA系列(四)一部署war 和 war exploded的区别
- 计算机的四个硬盘有什么区别是什么意思,笔记本的内存和硬盘有什么区别 原来笔记本硬盘有这几种...
- 【kafka】kafka单节点测试
- java server.xml_tomcat配置文件server.xml详解
- @贾跃亭,证监会喊你本周回国对乐视负责!
- 产品迭代发布如何更快速?阿里持续集成与持续交付实践之路全解析
- JAVA调用百度OCR实现身份证识别
- ztree 使用教程
- 车联网在智慧城市中的发展与应用
- Python面向对象加强2.Python 中类的内置属性和内置方法(魔法函数)
- Array Shrinking
- 学并发编程,透彻理解这三个核心是关键
- 关于荧光染料(FITC、RB罗丹明、Cy3,Cy3.5,Cy5,Cy5.5,Cy7,Cy7.5)
- 什么是同类群组联合学习 (FLoC)?
- 技术状态管理(六)-技术状态审核
热门文章
- 强化学习笔记3-Python/OpenAI/TensorFlow/ROS-规划博弈
- 微信小程序商城开发-商品详情页跳转购物车
- 【干货】一文详解计算机视觉的广泛应用:网络压缩、视觉问答、可视化、风格迁移等
- mmkv原理,Android多进程从头讲到尾,成功定级腾讯T3-2
- 【云原生】AI云开发平台——AI Model Foundry介绍(开发者可免费体验AI训练模型)
- 【练习】Accessing data with MySQL
- 机器学习环境配置(Tesla K80安装PyTorch的全过程)
- 新版HyperMesh的Assemblies中调出下拉菜单查看Component(装配关系模型树)
- 基于视频分析的rPPG心率检测
- Androi--内容提供器