📄
Henry
  • Henry的神秘小屋
  • 其他
    • 字节码与机器码的区别?
  • ObjectiveC
    • NSInvocation
    • 检测OC项目中未使用的方法
    • Method Selector
    • 消息转发
  • Swift
    • 检测Swift项目中未使用的类 方法 属性
    • NSCoding
    • Mirror
    • JSONEncode JSONDecode
    • Any AnyObject AnyClass
    • is as? as! as
  • Cocoapods
    • 看懂Podfile.lock文件
    • 在编写的Pod中使用宏预编译
  • iOS
    • 苹果应用 保持画面流畅
    • 关于计算机展示图像的一些问题
    • @testable
    • iOS中URLRequest的缓存策略
    • CodePush接入流程
    • H5在WKWebView中读取沙盒文件
    • FDLog App客户端日志系统
    • 如何实现JSBridge基于WKWebView
    • 网络请求各个指标的度量
    • iOS13 UIModalPresentationStyle
    • 实现H5离线包机制
    • NSURLProtocol 拦截器
    • Framework
    • Lock
    • CFNetwork NSURLSession NSURLConnection
    • setNeedsLayout layoutIfNeeded layoutSubviews
    • StackView
    • Flutter Method Channel:从Dart到Native调用链
    • JSONSerialization.ReadingOptions
    • JSONSerialization.WritingOptions
    • RunLoop高级2
    • RunLoop高级1
    • RunLoop中级
    • RunLoop初级
    • LineBreak AutoShrink
    • 如何给H5出WebView调试包
    • TODO、FIXME、!!!、???、MARK
    • Operation的使用
    • UserDefault
    • 了解WKWebView
    • 输出日志信息到系统控制台
    • Float Double 失去精度问题
    • 使用xcodebuild命令打包导出
    • 在iOS项目中使用C++定义的模块
    • 证书问题
    • 创建常驻线程
  • 源码
    • 阅读PINCache源码
    • 解读AspectHook
    • HandyJSON是如何实现的?
  • 汇编
    • 看懂汇编
由 GitBook 提供支持
在本页
  • 一,视图自动伸缩
  • 二,子 View 的布局
  • 总结:

这有帮助吗?

  1. iOS

StackView

上一页setNeedsLayout layoutIfNeeded layoutSubviews下一页Flutter Method Channel:从Dart到Native调用链

最后更新于5年前

这有帮助吗?

Demo:

在 iOS 的布局中,我们常常会做一些 按钮 间隔相等 之类的操作,在 StackView 没出现之前,都是通过额外的父层 View 来协助完成的。 接下来 我们看看 StackView 可以帮我们做哪些事情。

一,视图自动伸缩

先上一个效果图看下:

再看一下视图结构和代码:

WechatIMG1139.png

需要注意的是,StackView 是分横向和纵向的,如果是纵向的排列,我们不设置 Bottom 约束,只设置 Left,Top,Right,意味着这个 StackView 是可以无限延长的,根据内部的子 View 多少和相对关系。

如果是横向的,同样的道理,我们如果设置了,Left,Top,Bottom,意味着这个 StackView 可以向右面无限延伸,根据里面的子 View 多少和相对间距等决定。

代码基本一直,只为 StackView 设置了三个方向的约束。 分别是 Left, Top, Bottom。

如果现在还不清楚,没关系,我会把 Demo 项目一同给出。

二,子 View 的布局

注意 ⚠️: 如果你选择把几个 View 外面套上 StackView,那么你的几个子 View 会失去他们原有的约束,换句话说,更像是,StackView 通过配置给他们子 View 设置约束,不再给开发者去设置,StackView 提供了许多配置参数,我们来一同感受一下,他们都能帮助我们做什么。

其中 StackView 提供了几个配置选项,最重要的有三个选项,分别是:

  1. Axis: 横纵轴

    • Horizontal: 横向

    • Vertical: 纵向

  2. Alignment:对齐方式

    • Fill: 填充满

    • Top: 靠顶对齐

    • Center: 靠中间对齐

    • Bottom: 靠底部对齐

    • First Baseline / Last Baseline

  3. Distrubution: 子 View 之间的布局

    • Fill: 子 View 一个挨着一个填充 StackView

    • Fill Equally: 每一个子 View 被填充的地方都是一样大的

    • Fill Proportionally: 按照子 View 的多少进行分配大小

    • Equal Spacing: 保证每个子 View 的间距相同

    • Equal Centering: 保证每个子 View 的中心到其他邻近的子 View 中心相等。

总结:

有了 StackView,解决了 我们麻烦的 子 View 间的布局。

Jan072020135355.gif
WechatIMG1143.png

Demo: Demo 提供了,横向,纵向两个 Demo。

https://github.com/zColdWater/StackViewDemo
https://github.com/zColdWater/StackViewDemo
WechatIMG1144.png
Jan072020133232.gif
WechatIMG1145.png
WechatIMG1146.png
WechatIMG1147.png
WechatIMG1148.png
WechatIMG1149.png
WechatIMG1141.png
WechatIMG1150.png
WechatIMG1151.png
WechatIMG1152.png
WechatIMG1153.png
WechatIMG1154.png