今回は、簡単なStoryboard・AutoLayoutの説明を書きます。
前回
はじめてのSwiftアプリ制作3: CocoaPods と SwiftLint
環境
Xcode 8.3
Swift 3.0
Storyboardとは
![1.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2F310d5424-754c-7395-0d2a-2308bba58e99.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=39ae3d4c1cb9f90ae4a2109b8c414858)
アプリ全体の画面の表示や遷移を見ながら、パーツの追加や表示の制御ができるツールです。
右下に表示されている様々なパーツをViewController(1枚の画面)の中に入れて、アプリの画面を作っていくことができます。
また、AutoLayout機能を使って追加したパーツの表示に制約をつけてどのように表示するかを制御し、レスポンシブなデザインにすることができます。
AutoLayout入門
iOSのアプリ開発では、様々なデバイスやパターンに対応しなくてはいけないという注意点があります。
上記のページにあるように、iPhone・iPadは現在までに様々な画面サイズの機種が出ています。またLandScape(横向き)に対応する場合にはその場合での表示を考えなければなりません。
そのため、Viewの各パーツにAutoLayoutで正しい制約をつけないと、iPhone7では正しく表示されていたはずが4sやPlusといった異なる画面サイズの機種で表示が崩れていたりボタンが押せなかったりしてアプリ申請がreject(却下)される場合があります。
AutoLayoutは応用も含めるとかなりのパターンがありますが、ここでは制約編集ボタンを使った方法とコントロール+ドラッグを使った方法の2種類を紹介いたします。
- 制約編集ボタンを使った方法
![2.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2Fcdbd859b-8607-c432-dd22-5a82fd6d4dcc.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=e6e2f297e7ba63868025f63486bef229)
エディタ領域の右下に制約編集ボタンがあります。
こちらを使うことで各パーツに必要な制約を与えることができます。
左からStackボタン、Alignボタン、 Pinボタン、 Resolve Auto Layout Issuesボタンとなっています。
① Stackボタン
複数のビューを1つのスタックビューというものでグルーピングすることができます。
画面内で多くのパーツを入れたい場合は、このスタックビューを有効活用することでより簡単な設計にすることができます。
② Alignボタン
複数のパーツを選択した際に、それらの並び方を指定する制約ボタンです。
![5.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2F16e9dc62-cf16-ec4b-36da-44a23ff0df22.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=bd9839c54707a7eb1340f016609ea607)
項目 | 設定される並び替えの属性 |
---|---|
Leading Edges | 先頭に揃える |
Trailing Edges | 末尾に揃える |
Top Edges | 上に揃える |
Bottom Edges | 下に揃える |
Horizontal Centers | 縦方向で中央に揃える |
Vertical Centers | 横方向で中央に揃える |
Baselines | 横にベースラインで揃える |
Horizontally in Container | スーパービューとx軸で中央に揃える |
Vertically in Container | スーパービューとy軸で中央に揃える |
「Horizontally in Container」と「Vertically in Container」は中央に配置する用途でよく使用することになるかと思います。
③ Pinボタン
そのパーツからキャンバス上で最も近いパーツ、もしくはスーパービューとの距離での制約や大きさでの制約といった基本的な制約を追加することができます。
![6.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2F57464dfa-f22f-dd88-c788-48508d5e4100.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=942ec5b28e8d240803194ceac6b8a1c9)
項目 | 設定される制約 |
---|---|
Spacing to nearest neighbor | 最も近いパーツまたはスーパービューとの距離 |
Width | 幅 |
Height | 高さ |
Equal Widths | (複数のパーツを選択した際に)同じ幅 |
Equal Heights | 複数のパーツを選択した際に)同じ高さ |
Aspect Ratio | 縦横比 |
Align | (複数のパーツを選択した際に)Alignボタン参照 |
これらを使って各パーツに制約をつけることができますが、制約が不足している場合(その制約ではキャンバス上での表示位置を確定できない場合)や、制約が矛盾している場合はパーツを選択した際に赤い線で表示され、警告が起こります。
④ Resolve Auto Layout Issuesボタン
Auto Layoutに関する問題を解決するときに使用します。
![7.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2Feb216e23-7c2f-fe54-04bb-0e082bab564d.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=04154fdf89519740d5ba221e87cd2171)
項目名 | 解決内容 |
---|---|
Update Constaint Constants | キャンバス上の位置を正として制約を更新します。 |
Add Missing Constraints | 十分な制約が与えられていないパーツに足りない制約を自動的に追加します。 |
Reset to Suggested Constaints | 既存の制約を削除し、キャンバス上の位置を正とした制約を与えます。 |
Clear Constaints | 全ての制約情報を削除します。 |
- コントロール+ドラッグを使った方法
キャンバス上またはパーツ一覧から、パーツからパーツに対しての制約をつけることができます。
![3.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2F76efabd6-848a-50b1-cbca-dc0fc346bf45.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=b86716d8f9810d3cc5fb6900f4cb032f)
![4.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2F47b33497-c39e-1965-0411-dcf8e49d13c1.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=368c38fbde51a4f8e235e5f87d1e5267)
Equal Widths や Equal Heightsは相対的な大きさにしたいときに使うことが多いです。
設定した後にナビゲーション領域でmultiplierの値を変更することで、端末サイズの半分やあるパーツの1/3のサイズといった相対的なサイズを設定できます。
![8.png](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F189662%2Fc579dd24-2ffe-eb67-4f96-69c642c563ac.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=53708b788d1ff5215c8be606c1c919fd)
まとめ
- Storyboardではアプリ全体の画面の表示や遷移を見ながら、パーツの追加や表示の制御ができる。
- AutoLayout機能を使ってマルチデバイスに対応したレスポンシブデザインが実現可能
- AutoLayoutの使い方として、「制約編集ボタンを使う方法」と「コントロール + ドラッグを使う方法」などがある
Auto Layoutをすぐに理解するのは難しいので実践しつつ覚えていきましょう。
次は、簡単にマルチデバイス対応をする下準備について書きます。