UIStackView 浅析

今天学习了某个swift的教学视频,新发现了这个UIStackView,觉得可以研究下,与大家分享。
iOS 9中增加了新的控件:UIStackView,看下图就明白作用了。本来直接链接了官方文档的图片,不知道为何不能显示,只能再上传一次。


UIStackView Workflow

刚开始看到让我更多地想起 Word 里的文字排版,左对齐,居中之类,这里是对 UIView子类对象排版。找相似的控件的话可以说是 LineLayout 布局的 UICollectionView,不过更加灵活,可横向可竖向,还可以在 IB 里实时看到效果。在 UICollectionView 弄成这样的布局,还得好好设置一番。


LineLayout

我想到的第一个用处就是制作一个角色海报墙,类似这种:


妇联2角色海报

这要是用 UICollectionView 来实现,要实现 dataSource 方法,在 IB 中设置 Cell,调整布局参数,而使用 UIStackView,只需要拖进去几个 UIImageView,就会自动对齐,在 IB 如下设置就会有上面的效果:


Setting

当然,这个的效果可能还有一些瑕疵,也浪费我几个时间来调整细节,但得不到满意的效果。UIStackView 虽然小巧灵活,但是要想更精致的效果,最终还得靠 UICollectionView,看到微博上有人说这个类可能是脱胎于 Apple Watch,很可能,在那么小的屏幕上,还要拖各种约束来进行对齐和调整位置真是要烦死。弄了一通,觉得用处不大吧。在推上,看见很多开发者对这个类很是兴奋:
来自 twitter 上的看法


布局

因为 UIStackView 可以嵌套,实现以上的有丝分裂很方便,要是用 UICollectionView 简直要命。还有一位开发者说,这么多年了,终于有可以不滑动的 UITableView 了。由于我经验尚浅,不知道这些需求怎么产生的,或者我的脑洞还太小,不知道这个可以方便实现什么效果。

总体而言,UIStackView 实现有对齐要求的视图布局非常非常得简单,而使用 UICollectionView 和 UITableView 来实现就比较麻烦;还可以实时在 IB 里预览效果。最后有点很不方便的是,因为 UIStackView 是利用 UIView 类的 intrinsicContentSize 属性来计算布局,对不同长宽比以及分辨率的图片进行对齐和位置调整不是很给力,即使用 UIView 来进行封装来一层也基本无效,除了对原图片进行缩放,暂时还没有找到好的解决方案。

本文装载自http://www.jianshu.com/p/184e3fb94bd8。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值