AutoLayout好多好多不懂的 终于明白了
AutoLayout这玩意越用越上瘾 自从我学会了这个 还是那句话 能不用代码就不用代码
这篇文章不讲解AutoLayout 怎么使用 只是总结下最近学的东西 和更多你不知道的细节总结
本文大致讲解个部分
1 . UIStackView
2. AutoLayout与Frame的关系
3.AutoLayout动画
1 UIStackView
先推荐点资料
UIStakView入门 iOS 9新功能 具体支持到几我不清楚
看完这个你以后布局更方便了
举个例子 AutoLayout分分钟搞定等比例布局 之前我的帖子这样做
现在有了更简单的
2. AutoLayout与Frame的关系
曾经有次我被面试官问了一个面试题 如果你用了AutoLayout 再修改Frame 会有什么效果 有没有什么不好的
看这问题 所有人都能猜到肯定有不好的 但是具体也不知道是啥
看demo 一个view
3.AutoLayout动画
如果你用了AutoLayout 那么做动画的时候 你就不要再操作 Frame bounds center 等position属性
因为这些动画都是临时的 下次的View 被 setNeedsUpdateConstraint 这些全都失效
但是其他的可动画属性(Animation Properties) 还是可以的 如 Color alpha等
1. 更新约束的内容
针对 Constraint 一掉要调用LayoutIfNeed() 不然会造成不可预料的结果。 有可能下一刻动画剩下 也有可能然并卵 在NSLayoutConstraint中 唯一可变的 也就是 可set 可 get的属性就 constant
像其他FirstItem等是不可修改的 所以如果要修改参考物参看 下面的方法
2 . 替换约束的动画
添加约束可以通过
self.view.addConstraint(<#T##constraint: NSLayoutConstraint##NSLayoutConstraint#>)
self.view.addConstraints(<#T##constraints: [NSLayoutConstraint]##[NSLayoutConstraint]#>)
在iOS 8中有更好的方法 newConstraint.active=true 就可以