XIB、StoryBoard-约束

1. 基础篇

-目的:用自动布局(StoryBoard中)实现几个View等分屏幕

-效果图:

Snip20151130_3.png

-实现方法:

a.设置第一个view的约束(既灰色view),约束为上,左,下为0,0,0

b.设置第二个view的约束(既蓝色view),约束为上,左,下为0,0,0

c.设置第三个view的约束(既粉色view),约束为上,左,下为0,0,0

d.设置第四个view的约束(既橘色view),约束为上,左,下,右为0,0,0,0

e.选中四个View,设定四个View为等宽,如图

Snip20151130_4.png

2.进阶篇

目的:用自动布局(StoryBoard中)实现几个控件的等间距分割

效果图:(简版,约束版)(事例为距上方蓝线的约束)

Snip20151130_6.png

Snip20151130_5.png

实现方法

小TIPS:这里使用自动布局进行等间距分割的时候,要借助辅助的view控件

a. 对微博icon设置约束,约束为,上,左,宽,高为18,50,30,30

b. 设置其他三个icon与微博icon等宽,等高,等水平

c. 设置豆瓣icon距离上,右的约束为18,50

d. 拖三个view到四个icon中间,如图

Snip20151130_7.png

e.对三个view分别设定约束(相对于左侧icon)为水平居中,等高,左右约束为0,0

Snip20151130_8.png

Snip20151130_9.png

f.最后对三个view(选中)设定等宽

g.更新约束看看效果吧

3. iOS9.0更新(StackView)

注:该方法只能适配iOS9.0系统

将StackView拖动到StoryBoard中,设置好相应的约束,这个view就相当如一个容器,将想进行等间距的控件放入StackView中,并设定属性如图

Snip20151130_10.png

效果图:

在移动端开发过程中,可视化的搭建UI效率是非常高的,苹果官方也是强力推荐。我们现在来学一学如何利用系统自带的故事版(storyboard)来搭建UI。可视化搭建UI除了可以使用storyboard也可以使用xib。其实使用它们也是非常容易的,只需要在xcode的右下角处搜索控件的名字,然后拖拽到故事板上即可,如图

拖拉创建控件

(为了方便观看,我们先随便给它设个背景色)

设置控件的背景颜色

拖拽完之后。就是根据需求去设置控件的大小,以及屏幕的适配(iphone4~iPhone 6s plus、或者各种ipad型号)等。在这个设置大小的点,我们就要用到约束。以前用代码也是要用到约束去限制每个控件的大小的。因此约束的概念在这里也就不展开讲了。(假如你实在不想用约束的话,其实也是可以实现屏幕的适配的。可以用比例的大小去设置,类似于h5,用屏幕比例的方法,具体细节可以私聊)。现在主要讲讲如何实现给控件加上约束。

(现在先拖拉一个UIView来设置一个距离顶部的约束)

控件添加顶部约束

这样设置完顶部的约束之后就会出现如下的现象

添加第一个约束

出现红色说明还有欠缺的约束没有加完。顶部那个线就是我们添加的约束。假如我们先写距离顶部的距离是201。那么我们不论切换到哪个屏幕的大小View距离顶部的距离都是201。我们再往左边添加一个约束,然后设置它的宽高为100。即如图

去掉约束边缘

添加其他约束

约束完之后就可以了(如果出现的约束是蓝色的,说明约束正常)

约束完成

这样约束完之后的那个UIView的大小和位置就是固定的了。以后不论修改成哪个屏幕都是一样的。

不过这样有个缺点,它的距离的位置和大小是绝对的而不是相对的。假如你用iphone4s展示出这个界面,就觉得刚刚好的话,那么用iphone6就会显得有点偏,用例子看看,如图

iphone6模拟器运行效果

iphone4s模拟器运行效果

所以,我们应该得用相对位置和相对大小。用相对位置和相对大小的话,它是根据屏幕的大小去自动适配控件的位置和大小,这样子就可以比较符合开发员的预期需求。那么我们如何来做呢?我们来试试!

假如我们想让它水平居中,那么我们把原来的左边约束给删除,添加一个水平居中的约束点击View,然后点到约束的控制面板,找到左边的约束,选中,按delete删除

删除部分约束

(ps如果选不中约束按delete的话,会把整个View都删除掉的,不过不用担心,按command+Z撤销回来即可,然后再选中约束,把它删除掉)

删除完约束的效果

删除完约束之后约束会爆红是正常现象,不管它,我们来添加水平居中的约束,先点击View,然后点击约束约束,horizantally(水平)打上勾,选择update然后add上去,如图

添加水平居中约束

这样不论是在哪个屏幕上,我们的控件都水平居中了。

添加水平居中后的效果

这样就水平居中了。既然是相对约束,当然不止仅仅只能水平居中了,比如说我要偏左一点怎么办?偏右一点怎么办?改水平居中系数!看图说话

修改居中系数

点击那个edit出现后修改那个Multiplier,那个就是系数值,比1小就是往左,比1大就是往右,我们来设置一下0.6和1.8的效果看看

水平居中系数为0.6

(ps按command和-可以缩小故事版的视图,方便查看,按command和+就是放大,值得注意一点的是,至少要原故事版大小或者比原故事板大小的大才能在上面修改控件,不然顶多只能移动一下视图的位置而已。双击视图就可以恢复原大小了)

水平居中系数为1.8

这样看是不是很明显?那么这样就可以根据实际需求设定我们需要的位置了。垂直居中也是这样设置。就是选中水平约束下面那个(vertically)

垂直居中约束

写完相对位置之后,我们应该要来想想怎么设置相对大小了。为了方便演示,先把原来那个删除了,重新拉一个UIView。把它的大小和屏幕设置成等高等宽。

先选中当前控件和要等高等宽的父控件,把equal widths和equal heights打上勾就可以,add上去就可以了。

与父视图等高等宽

(ps这里要注意选择当前控件和要等高等宽的父控件按住command用鼠标点击左边的控件名就可以了,就是框起来的那两个)

添加完之后约束那里还是爆红,是因为我们还没有加位置约束,我们给它左边和上边都是0.0,这样就可以了

添加等高等宽约束

接下来点中View,选择约束,添加左、上为0

添加位置约束

OK,到这里就可以实现相对大小了。

添加完成约束的效果

根据那个相对位置的设置,同理的,我们想修改它不是满屏大小,也可以使用系数

相对大小的系数

我们把宽度修改成0.4试试

宽度为父控件的0.4

这样子View的宽度不论是切换到哪个屏幕都是占屏幕总宽的0.4大小了。宽高同理,想学习的自己慢慢尝试。

//居中约束

(1)拖拉一个View到LoginViewController.xib的视图上面,调整高度为300,我下面都称其为MiddleView吧,如下图所示,

为了让图片垂直居中显示,我们可以通过键盘的上(↑)下(↓)按键移动View。

(2)拖两个UITextField和一个UIButton到View上面,同时设置了MiddleView的背景色为LightGray,如下图所示,

(3)给MiddleView添加约束,使其水平和竖直居中,先选中MiddleView,然后按照下图操作,

(4)给MiddleView添加宽高(width and height)的约束,上面仅仅添加水平和垂直居中,会有警告,这是因为添加的约束还不够,如下图所示,添加宽高的约束,

(5)给MiddleView上面的空间添加相互间的约束,这时候添加约束就简单多了,先选中MiddleView上面所有的控件,只要点击一个Add Missing Constraints,,如下图所示,

通过上面一些简单的操作,保证登陆界面中的控件不管在3.5寸还是4寸的屏幕上面,都能够居中显示了。运行效果如下所示,

3.5寸屏幕效果图,

4寸屏幕效果图,

5、另外一种居中可以参考

水平居中:https://segmentfault.com/a/1190000002997979

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,290评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,399评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,021评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,034评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,412评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,651评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,902评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,605评论 0 199
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,339评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,586评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,076评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,400评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,060评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,083评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,851评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,685评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,595评论 2 270

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,569评论 25 707
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,206评论 0 17
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 11,616评论 4 59
  • 辞职这件事,我真的想了很久。我越认真的想,越认真的发现,这是一件必须百分之一百认真对待的事!近来,就辞职一事,反思...
    沧海一只猫阅读 552评论 2 3
  • 那天看完了电影 兴致盎然地和仙女说要写篇大作。 仙女说你有多久没正儿八经地写点儿字了呀。 哦 好久好久了... 那...
    Insight__阅读 233评论 0 0