iT邦幫忙

2024 iThome 鐵人賽

DAY 8
0
Mobile Development

Swift iOS UIKit 初學者系列:從零開始開發互動式應用系列 第 8

【Day 08】Auto Layout 修練 - 3 - 適應各裝置的 Size Classes:直向橫向佈局的最佳實踐

  • 分享至 

  • xImage
  •  

導言

在前一天的教學中,我們深入了解了 Auto Layout 的 Content Hugging Priority 和 Content Compression Resistance Priority,並學會如何通過調整這些優先順序來管理 UI 元件的大小變化。這些技巧幫助我們有效解決了不同螢幕尺寸下可能出現的文字溢出或空間分配不均的問題。

今天,我們將進一步探討 Auto Layout 的應用,特別關注如何利用 Size Classes 來針對不同裝置和螢幕方向調整佈局。在現代 iOS 開發中,應用程式必須能夠在多種裝置和不同方向的螢幕下順利運行。不同的使用情境下,使用者的期望佈局也會有所不同。例如,在手機的直向模式下,使用者往往會期待更簡潔、垂直排列的內容;而在橫向模式下,則更可能希望看到更豐富的信息或更便於操作的界面。透過 Size Classes,我們能夠靈活地調整應用的佈局設計,滿足這些需求。

今天學習目標

今天的學習目標是了解如何運用 Size Classes 來設計適應不同裝置與螢幕方向的佈局。透過這篇文章,你將學會如何在 iPhone 和 iPad 的直向與橫向模式下,靈活應用 Auto Layout,確保你的介面在各種螢幕尺寸和方向上都能正常顯示。重點包括設定不同的 Size Classes 和熟悉 wC, hC, wR, hR 的運作方式。

預覽效果

各個代表裝置及方向的截圖

Size Classes:為不同裝置提供彈性佈局

Size Classes 是 Auto Layout 提供的機制,用於指定某一佈局在不同裝置和螢幕方向下的表現。它包括兩種主要類型:

  • Compact (緊湊型):適用於空間有限的情況,像是 iPhone 的直向或 SE 橫向顯示。
  • Regular (常規型):適用於空間充裕的情況,像是 iPad 的直向和橫向顯示。

Size Classes 組合

這意味著我們需要考慮的排列組合有四種:

  • wC, hC(iPhone SE 的橫向)
  • wC, hR(iPhone 的直向: 如 iPhone 15 Pro Max)
  • wR, hC(iPhone 的橫向: 如 iPhone 15 Pro Max)
  • wR, hR(iPad 的直向和橫向)

通常我們只需要確保這四種情況的佈局正確即可,可以先測試以這三台直向跟橫向為主。

實際操作:設計四種布局

設定基本佈局 (直向)

首先,我們將設計直向佈局,這是最常見的使用場景。假設我們有一個簡單的圖片、標題和兩個按鈕。這裡是我們的初始佈局:

  • 圖片距離頂部邊界 10,保持 1:1 比例。
  • 文字標題距離圖片 10。
  • 兩個按鈕位於底部,彼此之間距離 10,且左右距邊界 10,按鈕長度相同。

橫向佈局的挑戰

當裝置旋轉至橫向時,可能會出現「跑版」的問題。例如,圖片變得過大,只看到部份圖片及按鍵。

我們需要重新調整佈局來適應橫向顯示。這時,我們要設定不同的 Auto Layout 來處理橫向佈局。

設定 Size Classes 在 Storyboard 中操作

在 Xcode 的 Storyboard 裡,我們可以使用右側的屬性面版最下方的 installed 按左邊的 +號,設定來區分不同的佈局:

  • 直向佈局 (wC, hR):先設置所有元件的佈局並加上 wC hR。

  • 橫向佈局 (wR, hC):切換至橫向佈局,剛剛直向的 iPhone 15 Pro Max 一轉橫向,可以發現全部的 Constraints 都變成了灰色

重新設定所有 Constraints,並指定 wR hC,把原本的 Installed 取消。

  • iPhone SE 橫向佈局 (wC, hC):針對小型螢幕進行優化,設定好 wC hC。
    接下來設定 iPhone SE 橫向,切過來果然跑版了,再重覆一次剛剛的動作。

設好一下我們想要的佈局,把每一個 Constraints 都加上 wC hC,把原本的 Installed 取消。

  • iPad 佈局 (wR, hR):iPad 直向和橫向都需要 wR hR 設定。
    接下來設定 iPad 橫向,切過來果然跑版了,再重覆一次剛剛的動作,可以發現 Constraints 已經多到超過螢幕高度啦。

設好一下我們想要的佈局,把每一個 Constraints 都加上 wR hR,把原本的 Installed 取消。

再來設定 iPad 直向,切過來一樣跑版了,再重覆一次剛剛的動作。但是因為直向跟橫向都是 wR hR,但長寬是不一樣的,設計上會有很大的挑戰。

每次新增條件約束 (Constraints) 時,要確保取消 已安裝 (Installed) 的原本佈局,並為每個方向提供專屬佈局。

你可能會發現,重複設定這些佈局時工作相對繁瑣,尤其是要為每一種方向都設置適合的 Auto Layout。這也是為什麼很多應用只支援單一方向的原因。

設定完成後,可以測試各個裝置和方向的顯示效果,確保每一種情境下都能正確呈現佈局。

結論:精準控制佈局的必要性

在處理多裝置的 Auto Layout 佈局時,Size Classes 是我們的好幫手。透過針對不同螢幕方向進行細緻設定,我們可以確保應用程式在各個裝置和螢幕方向上看起來都很完美。雖然這過程有點繁瑣,但在開發一個能適應所有裝置的應用程式時,這是不可或缺的步驟。

Auto Layout 的強大之處在於它可以應對不同的螢幕尺寸,讓我們的應用在任何情境下都表現得井井有條。掌握 Size Classes,你將能設計出真正自適應且流暢的 UI。

參考

附錄:已接觸的 UIKit 元件

  • UILabel (Day 01)– 顯示文字。
  • UIButton (Day 01)– 處理按鈕的點擊事件。
  • UIImageView (Day 01)– 顯示圖片。
  • UINavigationController (Day 02)– 管理畫面之間的導航。
  • Segue (UIStoryboardSegue) (Day 02)– 在畫面之間進行跳轉。
  • Relationship Segue (Day 03)– 建立控制器之間的層級關係。
  • UITabBarController (Day 03)– 實現底部的頁面導航。
  • UITableViewController (Day 04)– 顯示和管理大量的列表內容。
  • ScrollView (Day 05)– 呈現可捲動的內容。
  • Auto Layout (對齊、比例、間距) (Day 06)– 自動調整介面元素在不同裝置中的位置、大小和間距。
  • Auto Layout (擁抱、抗壓) (Day 07)– 當容器空間不足或過大時的元件的伸展及壓縮策略。
  • Auto Layout (Size Classes) (Day 08)– 針對不同裝置的直向與橫向佈局,讓應用程式在 iPhone 與 iPad 上適應不同的屏幕尺寸。

上一篇
【Day 07】Auto Layout 修練 - 2 - Content Hugging 與 Compression Resistance 的深入解析
下一篇
【Day 09】深入探索 UILabel:靈活的文字顯示與互動效果
系列文
Swift iOS UIKit 初學者系列:從零開始開發互動式應用30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言