SwiftUI-布局案例

介紹

import SwiftUI

struct ContentView : View {    
    var body: some View {
        Text("Hello World!")
    }
}

它的結(jié)構(gòu)如下:RootView —> ContentView —> Text砂代,那么 Text 是如何顯示在屏幕上的蹋订?官方的介紹是如下 3 個(gè)步驟。

  1. 父視圖為子視圖提供預(yù)估尺寸刻伊。
  2. 子視圖計(jì)算自己的實(shí)際尺寸露戒。
  3. 父視圖根據(jù)子視圖的尺寸將子視圖放在自身的坐標(biāo)系中。

最重要的是第 2 步捶箱,通常有 3 種設(shè)置尺寸的方式智什。

  1. 無(wú)需計(jì)算,根據(jù)內(nèi)容推斷丁屎,如 Image 根據(jù)圖片大小荠锭,Text 根據(jù)文字范圍。
  2. 使用 frame 強(qiáng)制指定寬高晨川。
  3. 設(shè)置縮放比例证九,如 Image 設(shè)置 aspectRatio。

frame

準(zhǔn)備一個(gè) 100*100 的圖片共虑。

struct ContentView: View {
    var body: some View {
        Image("img")
            .border(Color.black)
            .frame(width: 200, height: 200)
            .border(Color.blue)
    }
}
frame1.png

只有當(dāng) frame 大于內(nèi)容的尺寸時(shí)愧怜,alignment 才有意義。

struct ContentView: View {
    var body: some View {
        Image("img")
            .border(Color.black)
            .frame(width: 200, height: 200, alignment: .topTrailing)
            .border(Color.blue)
    }
}
frame2.png

Stack

案例一

struct ContentView: View {
    var body: some View {
        HStack(spacing: 10) {
            Image("img")
            
            Image("img")
        }
        .frame(width: 250, height: 200)
        .border(Color.blue)
    }
}

總寬度超過(guò) 2 個(gè) Image 和 spacing 之和看蚜,所以內(nèi)容在 HStack 中正常顯示叫搁。

Stack1.png
struct ContentView: View {
    var body: some View {
        HStack(spacing: 10) {
            Image("img")
            
            Image("img")
        }
        .frame(width: 140, height: 200)
        .border(Color.blue)
    }
}

總寬度小于 2 個(gè) Image 和 spacing 之和,所以內(nèi)容會(huì)超出 HStack。

Stack2.png

復(fù)雜案例

第 1 步:堆棧計(jì)算出內(nèi)部間距邊距渴逻,并將其從其父視圖建議的大小中減去疾党。
第 2 步:對(duì)于每個(gè)剩余視圖,堆棧將剩余空間分成相等的部分惨奕。然后選擇其中一個(gè)作為最不靈活的孩子雪位,從未分配的空間中扣除其大小,然后重復(fù)該過(guò)程梨撞。
第 3 步:所有的孩子都有尺寸以后雹洗,堆棧使用間距將它們對(duì)齊,并根據(jù)指定的對(duì)齊方式將它們對(duì)齊卧波。最后时肿,堆棧選擇自己的大小以便完全包含子級(jí)。

struct ContentView: View {
    var body: some View {
        HStack(spacing: 10) {
            Image("img")

            Text("所有的孩子都有尺寸以后港粱,堆棧使用間距將它們對(duì)齊螃成,并根據(jù)指定的對(duì)齊方式將它們對(duì)齊。最后查坪,堆棧選擇自己的大小以便完全包含子級(jí)寸宏。")

            Text("所有的孩子都有尺寸以后,堆棧使用間距將它們對(duì)齊偿曙,并根據(jù)指定的對(duì)齊方式將它們對(duì)齊氮凝。最后,堆棧選擇自己的大小以便完全包含子級(jí)望忆。")
        }
        .padding(.horizontal, 10)
        .frame(width: 280, height: 200)
        .border(Color.blue)
    }
}
  1. 總寬度間距為 300罩阵,其中間距為 2 * 10,邊距為 2 * 10炭臭,所以布局空間為:280-40 = 240永脓。
  2. 堆棧將空間分成 3 個(gè)相等的部分,每個(gè)部分的寬度為 80鞋仍。
  3. 將 80 這個(gè)尺寸推薦給最不靈活的孩子。案例中為 Image搅吁,其尺寸為 80x80威创。
  4. 堆棧從剩余空間中減去 Image 的寬度,因此剩余空間為 240-80 = 160谎懦。
  5. 堆棧再次將空間分成 2 個(gè)相等的部分肚豺,每個(gè)部分的寬度為 80。
  6. 它建議第 1 個(gè) Text 的大小為 80x200界拦。Text 回應(yīng)內(nèi)容不適合吸申,但它至少可以顯示一部分內(nèi)容。第 2 個(gè)文本視圖也是如此。因此截碴,盡管文本視圖的文本量不同梳侨,但它們的寬度都相同,都為 80日丹。
Stack3.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末走哺,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子哲虾,更是在濱河造成了極大的恐慌丙躏,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件束凑,死亡現(xiàn)場(chǎng)離奇詭異晒旅,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)汪诉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門敢朱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人摩瞎,你說(shuō)我怎么就攤上這事拴签。” “怎么了旗们?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵蚓哩,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我上渴,道長(zhǎng)岸梨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任稠氮,我火速辦了婚禮曹阔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘隔披。我一直安慰自己赃份,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般肴捉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上谒拴,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音涉波,去河邊找鬼英上。 笑死炭序,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的苍日。 我是一名探鬼主播惭聂,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼易遣!你這毒婦竟也來(lái)了彼妻?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤豆茫,失蹤者是張志新(化名)和其女友劉穎侨歉,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體揩魂,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡幽邓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了火脉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片牵舵。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖倦挂,靈堂內(nèi)的尸體忽然破棺而出畸颅,到底是詐尸還是另有隱情,我是刑警寧澤方援,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布没炒,位于F島的核電站,受9級(jí)特大地震影響犯戏,放射性物質(zhì)發(fā)生泄漏送火。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一先匪、第九天 我趴在偏房一處隱蔽的房頂上張望种吸。 院中可真熱鬧,春花似錦呀非、人聲如沸坚俗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)坦冠。三九已至,卻和暖如春哥桥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背激涤。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工拟糕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留判呕,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓送滞,卻偏偏與公主長(zhǎng)得像侠草,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子犁嗅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容