Help us understand the problem. What is going on with this article?

xcodeでAutoLayoutでレスポンシブデザイン

More than 3 years have passed since last update.

xcode6になって
対応しなければならない画面サイズ(解像度の比率の種類)が5種類に増えました
(iPhone4S,iPhone5(S),iPhone6(S),iPhone6 Plus(S)、iPad)

デバイスの画面サイズの種類が増えたことで
StoryboardやxibでAutoLayoutを使わないやり方でやると
1つのレイアウトファイルではマルチデバイスのサイズに
対応ができなくなってしまっています

自分は今までAutoLayoutを使って来なかったので苦戦したので
他の困っている人向けに備忘録として残しておきます

XCode7以降でも基本的には同じです。

長いです


まず、AutoLayoutを使わない方法もあります
ViewControllerを選択して
・Use Auto Layout
・Use Size Classes
のデフォルトチェックを外します。

スクリーンショット 2014-12-27 12.48.01.png

すると、従来通りAutoResizingが使えるようになります
スクリーンショット 2014-12-27 13.19.43.png

ただし、この方法だと
iPhone5からiPhone6へ解像度を変えたときに
Viewのx方向の中央揃えとかがうまくいかなかったりします
(画面縦横比が違うため)


ここからが本題のxcode6でのAutoLayoutでのレスポンシブデザインです。
xcode6からiPhone用レイアウトファイル、iPad用レイアウトファイル
と分けずに全て1つのレイアウトファイルで
レスポンシブデザインできるようになりました。
端末解像度別レイアウトするためには
Size Classesという概念が新しく導入されました。

storyboard内下段のwAny,hAnyをクリックするとレイアウトタイプを選択できます。

スクリーンショット 2014-12-27 13.34.28.png

分類は以下の表になっているようです。

autolayout.png

Size Classesを変更すると
目的別(端末の向き、対応解像度)に設定したレイアウトになります

正確にはおそらく違いますが
ざっくり以下のように覚えていて問題ないと思います
・Compact:iPhone6 Plus以外のiPhone用レイアウト
・Reqular:iPhone6 Plus、iPad用レイアウト
・Any:どの端末でも使えるレイアウト

今回はレスポンシブにしたいので5番目の横2セル、縦2セルのAnyを使います。

今回作成するレイアウトです
スクリーンショット 2014-12-27 12.43.25.png

ViewControllerのSimulated Matrics欄のSize項目から
各種端末サイズのプレビュー確認できます。

スクリーンショット 2014-12-27 13.53.46.png

AutoLayoutでの完成後レイアウトは次のようになります

3.5インチ(iPhone4S)
スクリーンショット 2014-12-27 12.44.26.png

4インチ(iPhone5,5S)
スクリーンショット 2014-12-27 12.44.36.png

4.7インチ(iPhone6)
スクリーンショット 2014-12-27 12.44.45.png

5.5インチ(iPhone6 Plus)
スクリーンショット 2014-12-27 12.44.53.png

iPadフルスクリーン
スクリーンショット 2014-12-27 12.45.43.png


では、下記の配置状態からAutoLayoutで実際に作っていきましょう

スクリーンショット 2014-12-27 14.19.48.png

AutoLayoutとはViewの配置やサイズにConstraints(制約)をつけることで
画面の解像度が変わってもその制約には従うことでレイアウトを保持するという概念です

制約なのでいくつかコツがあるみたいです
・基準となるView(中央のViewなど)を起点に制約をつけていくとやりやすい
・横方向の制約と縦方向の制約と切り分ける
・制約を追加する際に同じ方向にビューが多いと制約同士が衝突(コンフリクト)しやすい
・制約が足りない場合にも意図しないレイアウトになったりレイアウトエラーになる(位置だけでなくサイズの指定も必要)

今回の場合はTableViewを起点とします

①UITableViewの画面横方向を中央揃えにする
まず、TableViewを選択します。
その後、Controlキーを押しながらマウスドラッグして青い線を出し
親のViewへドロップします

Center Holizontally In Containerを選ぶと
親Viewに対して横方向中央揃えになります

スクリーンショット 2014-12-27 14.30.13.png

②画面サイズにあわせてUITableViewの横方向をリサイズする
UITableView選択状態で
Editor→Pinから
Leading Space to SuperViewを選択します
完了後
同様に
Trailling Space to SuperViewを選択してください

スクリーンショット 2014-12-27 14.37.07.png

・Leading Space to SuperView:左側のマージン
・Trailling Space to SuperView:右側のマージン
2つ設定すると画面サイズにあわせて横幅がリサイズされるようになります
(プレビューで確認してみてください)

ここまでで赤い矢印が表示されるようになると思います
スクリーンショット 2014-12-27 15.09.46.png

赤い矢印をクリックすると
Y方向の位置と高さが指定されていないというレイアウトエラーが出ています

スクリーンショット 2014-12-27 15.09.32.png

なので次に縦方向に関しての制約も追加していきます

③画面サイズにあわせてUITableViewの縦方向をリサイズする
UITableViewに
・Bottom Space to SuperView:親ビューに対する下側のマージン
を追加します。
次にUITableViewを選択しControlキーを押しながらマウスドラッグし
一括投稿UIButtonにドロップします
・Vertical Spacing:ビュー間のマージン
を追加します

スクリーンショット 2014-12-27 15.21.17.png

同様に
一括投稿UIButtonからUITextFieldへVertical Spacingします

次にUITextFieldで
・Top Space to SuperView:親ビューに対する上側のマージン
を選択します

ここまでで縦方向に関する制約が揃ったので
UITableViewに関しては画面サイズを変えても
リサイズされるようになるはずです

スクリーンショット 2014-12-27 15.35.36.png

後は残っている他のViewに対して制約を追加していきます

④一括投稿UIButtonとUITextFieldをUITableViewに揃える
一括投稿UIButtonからControlキーを押しながらUITableViewへドラッグドロップして
・CenterX:ビュー間の横方向揃え
を追加します

スクリーンショット 2014-12-27 15.47.33.png

同様に
UITextViewから一括投稿UIButtonへCenter Xします

次にUITextViewからUITableViewにドラッグドロップし
・Equal Widths:ビュー同士の幅を同じにする
を追加します

ここまで行うと
一括投稿UIButtonとUITextFieldに関して画面サイズに合わせて
追従するようになります

スクリーンショット 2014-12-27 16.05.10.png

⑤twitter,Facebookアイコンとコントロールを画面サイズに合わせる
・twitterのUIImageView
・twitterのUISwitch
・facebookのUIImageView
・facebookのUISwitch
それぞれをUITextFieldに対してVertical Spacingします

スクリーンショット 2014-12-27 16.08.37.png

次に
・twitterのUIImageView
・twitterのUISwitch
・facebookのUIImageView
・facebookのUISwitch
それぞれをUITextFieldに対してCenter Xします

その後
・twitterのUIImageViewとtwitterのUISwitch間
・twitterのUISwitchとfacebookのUIImageView間
・facebookのUIImageViewとfacebookのUISwitch間
に対してそれぞれ
・Horizontal Spacing:ビュー間横方向マージン
をします
スクリーンショット 2014-12-27 16.22.49.png

最後に
twitterのUIImageViewとfacebookのUIImageView
に対して
UIImageView選択後にEditor→Pinから
から
・Width:画面サイズによらず幅を固定する
・Height:画面サイズによらず高さを固定する
の制約を追加します

スクリーンショット 2014-12-27 16.29.55.png

ここまでやると完成です。
画面サイズを変えてもレスポンシブなレイアウトになります

スクリーンショット 2014-12-27 16.33.57.png

⑥レイアウトが反映されていない場合
画面サイズを変えた場合に
Constraints(制約)通りのレイアウトになっていない場合は
・Update Frame
をすることで作成した制約に基づいて正しい位置にfixされます

スクリーンショット 2014-12-27 16.37.51.png

スクリーンショット 2014-12-27 16.40.40.png


AutoLayoutのよく使うConstraints(制約)まとめ

画面中央揃え
・Center Holizontally In Container:横方向中央揃え
・Center Vertically In Container:縦方向中央揃え
・CenterX:ビュー間の横方向揃え
・CenterY:ビュー間の縦方向揃え
マージン、オートリサイズ
・Leading Space to SuperView:親ビューに対する左側のマージン
・Trailling Space to SuperView:親ビューに対する右側のマージン
(2つ設定すると画面サイズにあわせて横幅がリサイズされる)
・Top Space to SuperView:親ビューに対する上側のマージン
・Bottom Space to SuperView:親ビューに対する下側のマージン
(2つ設定すると画面サイズにあわせて縦高さがリサイズされる)
・Horizontal Spacing:ビュー間横方向マージン
・Vertical Spacing:ビュー間縦方向マージン

幅、高さ揃え
・Equal Widths:ビュー同士の幅を同じにする
・Eqaul Heights:ビュー同士の高さを同じにする
・Width:画面サイズによらず幅を固定する
・Height:画面サイズによらず高さを固定する

teradonburi
気管支喘息を患って死にかけです。 いつ死ぬかわかりません。 成人喘息は誰でもなりえるものだし、 咳喘息から気管支喘息に進行すると慢性的な死の危険があるものです。 自身や周りで数週間咳が続いてる人がいたら気をつけて・・・ Twitterフォローいただけたらフォロバします。 https://twitter.com/teradonburi
meetsmore
プロを探せる見積りプラットフォーム「ミツモア」の開発・運営
https://meetsmore.com
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした