iOS开发之autoLayout constraint
前言
ios设备的尺寸越来越多,针对一款app可能要适配到多种设备。多种尺寸。所以。我们期望我们的app可以autoLayout。本文主要介绍在Xcode中使用constraint。未来会不定期对此文进行更新。
约定
本文中view指代从Objuect Library中拖拽出来的各种view
基础
一个view在界面显示,至少有三种决定条件
- 一、自身大小:如width、height
- 二、相对于父容器的位置:如固定起始坐标位置或相对位置
- 三、相对于兄弟view的位置:如顶部对齐、左右距离、堆叠层次
思路
在storyboard中,拖拽出来的view都有默认的样式,在拖动的过程中会有蓝色的辅助线,帮助我们布局。可是位置大小等都是固定的,我们须要给每一个view设置constraint,告诉它在不同的情况下应该怎样表现。
编译执行Label并没有垂直水平居中
布局的过程,就是确定view的水平位置、垂直位置以及相对位置
需求
一种常见的情况:一个搜索框,一个搜索button
搜索框:长度要随着界面变化进行伸缩。与确定button间距20,距离左边0。顶部10,高40
确定button:顶部10,右边0,与搜索框间距20,宽50。高40
先来看下终于效果
imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" class="imagebubble-image" alt="" style="">
实现步骤
- 1、拖拽一个
text Field,一个Button到storyboard - 2、注意storyboard底部的button
constraintbutton三个button各自是
Align: 主要用来进行兄弟view对齐
Pin:自身大小、相对容器位置
Resolve auto layout issues:应用constraint后更新storyboard 3、选中
Button,点击Pinbutton,上边距10,分别设置左边距20,右边距0,高度40,宽度50(button的宽度基本是固定的)
宽度和高度都是描写叙述自身大小,条件一
上边距和右边距都是相对父容器,条件二
左边距是相对于兄弟view的位置,条件三imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" class="imagebubble-image" alt="" style="">
Button constraint点击
Add 5 Constraints
结果就变成下边的样子了
结果4、这个时候,我们点击
Resolve auto layout issues,并选择Selected下的
ViewsUpdate FrameimageMogr2/auto-orient/strip%7CimageView2/2/w/1240" class="imagebubble-image" alt="" style="">
Update Frame5、如今同一时候选中
Button和text,点击
FieldAlignbutton。勾选Top,从icon上我们就能够看出来,是顶部对齐的意思
Edges
顶部是相对于兄弟view的位置。条件三。
同一时候。隐含的text Field相对父容器顶部的位置和Button一样,条件二
Top Edges点击 Add 1 Constraints
Add 1 Constraints点击Resolve auto layout issues ,选择Selected下的
ViewsUpdate Frame
Update Frame- 6、如今选中
text Field,点击Pinbutton。设置左边距0和高度40。点击Add
2 Constraints
高度40。条件一
左边距,条件二
隐含的,宽度是从父容器到搜索button的左边20的位置,条件一
text Field左边距点击Resolve auto layout issues ,选择Selected下的
ViewsUpdate Frame
Update Frame结果改动Button的文字为搜索就算完毕啦~
iOS开发之autoLayout constraint的更多相关文章
- iOS开发之Autolayout
1.概述 在以前的iOS程序中,是如何设置布局UI界面的? (1)经常编写大量的坐标计算代码 (2)为了保证在3.5 inch和4.0 inch屏幕上都能有完美的UI界面效果,有时还需要分别为2种屏幕 ...
- iOS开发之AutoLayout中的Content Hugging Priority和 Content Compression Resistance Priority解析
本篇博客的内容也不算太复杂,算是AutoLayout的一些高级的用法.本篇博客我们主要通过一些示例来看一下AutoLayout中的Content Hugging Priority以及Content C ...
- 李洪强iOS开发之iOS好文章收集
李洪强iOS开发之iOS好文章收集 该文收集朋友们转发或自己的写的技术文章,如果你也有相关的好文章,欢迎留言,当好文章多的时候,我会对这些好文章进行分门别类 文章 简述 日期 直播服务配置 使用 ng ...
- iOS开发之Socket通信实战--Request请求数据包编码模块
实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...
- iOS开发之UISearchBar初探
iOS开发之UISearchBar初探 UISearchBar也是iOS开发常用控件之一,点进去看看里面的属性barStyle.text.placeholder等等.但是这些属性显然不足矣满足我们的开 ...
- iOS开发之UIImage等比缩放
iOS开发之UIImage等比缩放 评论功能真不错 评论开通后,果然有很多人吐槽.谢谢大家的支持和关爱,如果有做的不到的地方,还请海涵.毕竟我一个人的力量是有限的,我会尽自己最大的努力大家准备一些干货 ...
- iOS开发之 Xcode6 添加xib文件,去掉storyboard的hello world应用
iOS开发之 Xcode6.1创建仅xib文件,无storyboard的hello world应用 由于Xcode6之后,默认创建storyboard而非xib文件,而作为初学,了解xib的加载原理 ...
- iOS开发之loadView、viewDidLoad及viewDidUnload的关系
iOS开发之loadView.viewDidLoad及viewDidUnload的关系 iOS开发之loadView.viewDidLoad及viewDidUnload的关系 标题中所说的3个方 ...
- iOS开发之info.pist文件和.pch文件
iOS开发之info.pist文件和.pch文件 如果你是iOS开发初学者,不用过多的关注项目中各个文件的作用.因为iOS开发的学习路线起点不在这里,这些文件只会给你学习带来困扰. 打开一个项目,我们 ...
随机推荐
- Python使用装饰器自动调用父类__init__
众所周知,Python中class的构造函数实际是__new__(),但是如果我们执行p1=Point()的时候,不仅会调用Point的__new__方法,而且会调用Point的__init__方法. ...
- 基于mkdocs-material搭建个人静态博客
基于mkdocs-material搭建个人纯静态博客,没有php,没有mysql 如果你只是想安安静静的放一些技术文章,发布到个人站点或github-pages,mkdocs-material很适合你 ...
- 一个 passive 引发的bug
不是什么很难的东西,权且做个记录. 首先说下背景,目前的项目中,需要同时绑定 wheel 和 scroll 事件. 绑定 wheel,目的是开发 ctrl + wheel 缩放页面功能,此功能与浏览器 ...
- MVC HtmlHelper扩展——实现分页功能
MVC HtmlHelper扩展类(PagingHelper) using System; using System.Collections.Generic; using System.Collect ...
- [转]Java设计模式学习心得
http://tech.it168.com/focus/200902/java-design/index.html http://tech.it168.com/j/2007-05-17/2007051 ...
- 适配器模式(adapter)C++实现
意图:将一个类的接口转换成客户希望的另一个接口. 适用性:1.你想使用一个已存在的类,而它的接口不符合你的需求. 2.你想创建一个可以复用的类,该类可以与其它不相关的类或不可预见的类协同工作. 类适配 ...
- tween.js 中文使用指南
tween.js 英文使用指南 首先来看个例子: hello,tween.js 补间(动画)(来自 in-between)是一个概念,允许你以平滑的方式更改对象的属性.你只需告诉它哪些属性要更改,当补 ...
- vue2.0.js
数据的渲染.数据同步 组件化.模块化 路由 ajax 数据流 Vue.js学习资源 中文官网:http://cn.vuejs.org/ 源码:http ...
- hdu3488 / hdu3435 / hdu1853 最小费用最大流 圈 拆点
题目大意: 在一个有向图中,求经过所有点的最小圈. 思路: (如果是用二分图的完美匹配来做,那么直接上模版就好了).http://www.cnblogs.com/Potato-lover/p/3991 ...
- hdu3416 Marriage Match IV 最短路+ 最大流
此题的大意:给定一幅有向图,求起点到终点(都是固定的)的不同的最短路有多少条.不同的最短路是说不能有相同的边,顶点可以重复.并且图含有平行边. 看了题以后,就想到暴力,但是暴力往往是不可取的.(暴力的 ...