iOS StackView 布局视图

发布于 2024-08-20 12:10:52 字数 3593 浏览 13 评论 0

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

一,视图自动伸缩

先上一个效果图看下:

Jan072020133232.gif

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


WechatIMG1139.png

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

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


Jan072020135355.gif

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

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

二,子 View 的布局

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

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


WechatIMG1143.png

  1. Axis: 横纵轴
    • Horizontal: 横向

      WechatIMG1144.png

    • Vertical: 纵向

      WechatIMG1145.png

  2. Alignment:对齐方式
    • Fill: 填充满

      WechatIMG1146.png

    • Top: 靠顶对齐

      WechatIMG1147.png

    • Center: 靠中间对齐

      WechatIMG1148.png

    • Bottom: 靠底部对齐

      WechatIMG1149.png

    • First Baseline / Last Baseline

      WechatIMG1141.png

  3. Distrubution: 子 View 之间的布局
    • Fill: 子 View 一个挨着一个填充 StackView

      WechatIMG1150.png

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

      WechatIMG1151.png

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

      WechatIMG1152.png

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

      WechatIMG1153.png

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

      WechatIMG1154.png

总结

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

Demo: https://github.com/zColdWater/StackViewDemo Demo 提供了,横向,纵向两个 Demo。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

独孤求败

暂无简介

0 文章
0 评论
23 人气
更多

推荐作者

xu362930323

文章 0 评论 0

缱倦旧时光

文章 0 评论 0

qq_eXruk9

文章 0 评论 0

遂心如意

文章 0 评论 0

guojiayue1

文章 0 评论 0

愿与i

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文