从iOS9开始,苹果提供了UIStackView来帮助我们做布局,这玩意儿类似于安卓的线性布局。因为在使用过程中会遇到一些坑,所以写出来供遇到同样问题的人参考。我在这里提供xib和纯代码两种方式创建使用 UIStackView:

先看一下运行效果:

  

垂直方向,在图一里,label被拉伸了,在图2里面,label和image被压缩了

1、xib方式

打开storyboard之后会发现右下角多了一个图标:

在xib中创建 UIStackView 要用到这个按钮,就称它为 stack 按钮吧。

首先拖三个控件进来:

然后按住 command键,然后选中这三个View,然后点击右下角的哪个 stack 按钮。这时候就创建了一个 UIStackView,这个stackView包括了刚才选中的三个View:

图里面绿色箭头指向的就是我们刚刚创建的UIStackView。

而右上角的红色箭头指向的错误让人纠结了。导致错误的原因有多个,我们来一个一个的解决。

第一个原因:stackView没有约束。

说来奇怪,使用xib创建UIStackView的时候,不能设置 stackview的frame,你看是灰色的:

没办法,不能设置frame,那就设置约束吧,选中stackView,然后给它添加约束如下:

然后我们看一下结果如何:

效果马马虎虎了,可是TNND还是有错误:

点进入看给的错误信息,大概意思是需要设置抗压缩等级——这是啥?

这还得从 UIStackView 的排布方式说起,选中stackView,在右侧工具栏查看这个:

挨个说说,

Axis(轴):这里代表stackView所包含的View的排布方向,有竖直和水平两种,这玩意儿比较智能,在你添加的时候能够自动判断。你也可以咋这里更改。

Alignment(对齐方式):是指stackview所包含的View的对其方式,有下面几种方式:

Fill:子View填充 stackView,它会使子View在水平和垂直方向都填充stackView

Leading:靠左对其

Trailing:靠右对齐

Center:中心对齐

Top:顶部对齐

Bottom:底部对其

Distribution(分布):是指 stackview 的子 View的排布方式,有下面几种方式:

Fill:默认方式,子View加起来田中整个 stackview

Fill Equally:子View的高度/宽度一致(具体是哪一个一致得看是水平排布还是垂直排布)

Fill Proportionally:StackView 自己计算出它人为合适的排布方式,合理分配宽/高

Equal Spacing:子View保持同等间隔的排布方式

Equal Centering:每个子View的中心线之间距离相同的排布方式,每个子view的宽/高会适配其内容

之所以会出现上面的错误,是由于 Fill、Equal Spacing 这两个方式不能自动地对子View进行压缩/拉伸(在子View填充的大小与stackview不符合的情况下)。例如本文的情况,子View的大小加起来比stackView要大,而在Fill模式下,系统又不知道该压缩哪一个View,所以才报了错。加入将Fill模式换成 Fill Equally、Fill Proportionlly、Equal Centering就不会出错了。

下面来解决上面的这个问题:

首先在右侧的工具栏选中尺子

在里面找到下面这两个东西:

三个子View都有这两个属性

Content Hugging Priority:压缩优先等级,这个值越低,越容易被拉伸

Content Compression Resistance Priority:抗压缩优先等级,这个值越低越容易被压缩

所以将其中一个View的上面这两个属性调低,使这个View能够被压缩/拉伸,就可以解决上面的问题了

例如,将label的调低,就能解决问题了

----ps,感觉xib使用stackView还是有一些问题的

2、代码的方式:

func createStackView(){

//使用代码的方式创建stack的时候是可以使用frame的,当然,也可以使用约束

let stack = UIStackView(frame: CGRect(x: 10, y: 20, width: 300, height: 600))

let btn = UIButton(type: UIButtonType.Custom)

btn.backgroundColor = UIColor.greenColor()

btn.setTitle("btnbtn", forState: UIControlState.Normal)

btn.setTitleColor(UIColor.blueColor(), forState: UIControlState.Normal)

stack.addArrangedSubview(btn)

let label = UILabel()

label.backgroundColor = UIColor.lightGrayColor()

label.text = "aaaabbbbccccddddeeeeffffgggghhhhiiiijjjjjkkkklllmmmnnn"

label.numberOfLines = 0

stack.addArrangedSubview(label)

let img = UIImageView()

img.image = UIImage(named: "2")

stack.addArrangedSubview(img)

stack.alignment = UIStackViewAlignment.Center

stack.axis = UILayoutConstraintAxis.Vertical

//下面这两行是Fill模式的

stack.distribution = UIStackViewDistribution.Fill

label.setContentHuggingPriority(249, forAxis: UILayoutConstraintAxis.Vertical)

//        stack.distribution = UIStackViewDistribution.FillEqually

//        stack.distribution = UIStackViewDistribution.FillProportionally

//        stack.distribution = UIStackViewDistribution.EqualSpacing

self.view.addSubview(stack)

print(">>>>>>")

}

豆电雨 摘自 http://my.oschina.net/javaeee/blog/514653

UIStackView相关的更多相关文章

  1. iOS9新特性-UIStackView

    1. UIStackView相关属性理解 UIStackView是iOS9之后推出的,我也是第一次接触,在学习的过程中对于其中的相关属性,尤其是对其中的distribution几个属性值,一知半解的, ...

  2. iOS10 UI设计基础教程

    iOS10 UI设计基础教程 介绍:本教程针对iOS初级开发人员,基于iOS 10系统,使用Swift 3.0语言讲解如何进行UI设计.本教程内容涵盖UI基础构成.UI元素.自动布局.自适应UI.UI ...

  3. 嵌入式单片机STM32应用技术(课本)

    目录SAIU R20 1 6 第1页第1 章. 初识STM32..................................................................... ...

  4. iOS9新特性——堆叠视图UIStackView

    一.引言 随着autolayout的推广开来,更多的app开始使用自动布局的方式来构建自己的UI系统,autolayout配合storyBoard和一些第三方的框架,对于创建约束来说,已经十分方便,但 ...

  5. iOS开发——UI篇OC篇&UIStackView详解

    UIStackView详解 一.继承关系.遵守协议.隶属框架及可用平台 UIStackView 类提供了一个高效的接口用于平铺一行或一列的视图组合.Stack视图使你依靠自动布局的能力,创建用户接口使 ...

  6. 制作一个类似苹果VFL的格式化语言来描述UIStackView

    在项目中总是希望页面上各处的文字,颜色,字体大小甚至各个视图控件布局都能够在发版之后能够修改以弥补一些前期考虑不周,或者根据统计数据能够随时进行调整,当然是各个版本都能够统一变化.看到这样的要求后,第 ...

  7. iOS 开发之UIStackView的应用

    ————————————————UIStackView的应用———————————————— 一:先讲下优势: 对于排布列表式控件的布局需求,用UIStackView控件,开发中为我们省去了繁琐的代码 ...

  8. java中的字符串相关知识整理

    字符串为什么这么重要 写了多年java的开发应该对String不陌生,但是我却越发觉得它陌生.每学一门编程语言就会与字符串这个关键词打不少交道.看来它真的很重要. 字符串就是一系列的字符组合的串,如果 ...

  9. SQL Server相关书籍

    SQL Server相关书籍 (排名不分先后) Microsoft SQL Server 企业级平台管理实践 SQL Server 2008数据库技术内幕 SQL Server性能调优实战 SQL S ...

随机推荐

  1. Linux开发工具之gdb(上)

    三.gdb调试(上) 01.gdb:gdb是GNU debugger的缩写,是编程调试工作. 功能:   启动程序,可以按照用户自定义的要求随心所欲的运行程序:   可让被调试的程序在用户所指定的调试 ...

  2. (转)JavaWeb学习总结(十三)——使用Session防止表单重复提交

    如何防止表单重复提交 在平时开发中,如果网速比较慢的情况下,用户提交表单后,发现服务器半天都没有响应,那么用户可能会以为是自己没有提交表单,就会再点击提交按钮重复提交表单,我们在开发中必须防止表单重复 ...

  3. C#实现自动切割图片

    由于做一个TD游戏需要一些图片素材,可是现有的从网上下载的<保卫萝卜>的图片资源是多张图片合在一起的,并且没有什么规则,虽然有 个xml文件似乎用来描述此图片内子图片位置大小等信息,但由于 ...

  4. 【转载】ASP.NET线程安全与静态变量的生命周期浅谈

    ASP.NET线程安全所涉及的是什么呢?让我们先来看看静态变量的生命周期问题,下面是我理解的静态变量的生命周期: void Application_Start开始 void Application_E ...

  5. C# Wpf集合双向绑定

    说明: msdn中   ObservableCollection<T> 类    表示一个动态数据集合,在添加项.移除项或刷新整个列表时,此集合将提供通知. 在许多情况下,所使用的数据是对 ...

  6. SQL 查询的执行过程

    所述内容均来自互联网,文章仅作为学习笔记,备忘使用. 有时候我在想我们总是在谈优化,FA 优化结构.优化框架.优化程序…,可是我真的了解将要进行的操作[优化]吗?以最近我的工作-优化SQL为例,我真的 ...

  7. 19 Remove Nth Node From End of List(去掉链表中倒数第n个节点Easy)

    题目意思:去掉链表中倒数第n个节点 思路:1.两次遍历,没什么技术含量,第一次遍历计算长度,第二次遍历找到倒数第k个,代码不写了   2.一次遍历,两个指针,用指针间的距离去计算. ps:特别注意删掉 ...

  8. DropDownList自动生成年月日

    DropDownList自动生成年月日 aspx页面上有三个dropdownlist控件, dropdownlist1 表示年,dropdownlist2表示月,dropdownlist3表示天: 注 ...

  9. thinkphp框架之模型(数据库查询)

    1. 模型定义 文件名称必须是 表名+Model.class.php 例如:UserModel.class.php namespace Home\Model; //该模型类的命名空间 use Thin ...

  10. Lang语言包

    \languages\zh_cn\admin\common.php里配置后台所有常量