日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Stack View 自定义间隙

發(fā)布時(shí)間:2025/3/21 编程问答 66 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Stack View 自定义间隙 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

翻譯自:https://useyourloaf.com/blog/...

Apple 在 iOS9 引入了 StackView,使用它可以減少約束的數(shù)量,讓使用 AutoLayout 更加容易。但有一種邊界使用場(chǎng)景是需要自定義視圖之間的間隙。這種情況可以使用嵌套布局的方式來(lái)解決,但解決方案有些復(fù)雜。在 iOS 11 中給出了解決方案,你可以在 StackView 中自定義視圖之間的間隙。

問(wèn)題描述

這是我想創(chuàng)建的布局:

如圖所示,共有5個(gè) Label。最上面的大字 Label,中間三個(gè)標(biāo)準(zhǔn) Label,以及最下面的小字 Label。中間三個(gè) Label 的間隙是 8pt,最上面和最下面的兩個(gè) Label 的間隙是 32pt。

UIStackView 在相等距離垂直分配視圖的情況下工作的很好。通過(guò)設(shè)置 StackView 的間隙屬性,每個(gè)子視圖的間隙是相等的。

Stacking Stacks

使用內(nèi)嵌 StackView 的方式實(shí)現(xiàn)布局。

Inner StackView 包含三個(gè) Label,8pt 的間隙,外部 StackView 有 32pt 的間隙。這看起來(lái)能工作,實(shí)則可能是引入了麻煩。比如我想 header 和 footer 的間隙不一樣,這就很麻煩。

自定義間隙(iOS 11)

在 iOS 11中,給某個(gè) stackView 中的元素自定義間隙成為可能。假設(shè)我們已經(jīng)構(gòu)建好一個(gè) stackView:

let stackView = UIStackView(arrangedSubviews: [headerLabel, topLabel, middleLabel, bottomLabel, footerLabel]) stackView.axis = .vertical stackView.alignment = .fill stackView.spacing = 8.0

stackView 中的每個(gè)元素間隙是8pt。想要自定義header 標(biāo)簽和 footer 標(biāo)簽的間隙,可以直接調(diào)用 iOS11 的方法設(shè)置:

// iOS 11 only stackView.setCustomSpacing(32.0, after: headerLabel) stackView.setCustomSpacing(32.0, after: bottomLabel

說(shuō)明:

  • 你可以指定某個(gè) stackView 子元素之后的間隙,但是目前沒(méi)有方法指定之前的間隙。
  • 在 InterBuilder 中,你無(wú)法設(shè)置自定義間隙。只能在代碼中完成。
  • 當(dāng)你 從 stackView 中移除元素,系統(tǒng)自動(dòng)移除自定義間隙。

標(biāo)準(zhǔn)間隙和默認(rèn)間隙

UIStackView 在 iOS 11中增加了兩個(gè)新屬性,定義了系統(tǒng)間隙和默認(rèn)間隙的值:

class let spacingUseDefault: CGFloat class let spacingUseSystem: CGFloat

這兩個(gè)屬性的值是由系統(tǒng)保存和定義的,使用的時(shí)候不要直接保存他們的返回值。系統(tǒng)間隙似乎返回8pt,還是再?gòu)?qiáng)調(diào)一下,使用的時(shí)候應(yīng)該直接訪問(wèn)這兩個(gè)屬性而不是保存他們的值。

你可以用這兩個(gè)屬性設(shè)置或者恢復(fù)自定義的間隙。

將系統(tǒng)間隙的值設(shè)置給最上面的 label:

stackview.setCustomSpacing(UIStackView.spacingUseSystem, after: topLabel)

恢復(fù) stackView 元素的間隙(移除自定義的間隙):

stackview.setCustomSpacing(UIStackView.spacingUseDefault, after: topLabel)

譯者注:
在設(shè)置了 stackView 的 spacing 值為5,設(shè)置 customSpacing 的值為10,然后界面調(diào)整了,想把自定義間隙恢復(fù)為5,那么這時(shí)只能調(diào)用 setCustomSpacing 將值設(shè)置為 spacingUseDefault,如果設(shè)置為0,將干掉所有的間隙。這是我理解的 spacingUseDefault 使用場(chǎng)景。

總結(jié)

以上是生活随笔為你收集整理的Stack View 自定义间隙的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。