StoryBoardを使わずにXibで画面を作る
1ViewController,1StoryBoardで開発していると言うことをよく聞きますが、私のプロジェクトは1ViewController,1Xibで開発しています。
せっかくなのでXibでの開発方法をまとめます。
新規viewControllerにxibを作成する場合
新規で作成する場合は簡単です。Also Create Xib fileにチェックを入れてviewControllerを作成します。
data:image/s3,"s3://crabby-images/737f6/737f6c6e60ea8a50e34afb1c19e5984384d18bf8" alt=""
今回はTestViewControllerと言う名前でviewControllerを作成したのでTestViewController.xibと言うファイルが自動生成されているはずです。
このxibファイルにauto layoutでレイアウトの設定を行い画面を作っていきます。
既存のviewControllerにxibを作成する場合
xibファイルの生成
File > New > FileからViewを選択して作成します。
data:image/s3,"s3://crabby-images/f8eec/f8eec5f5bb6ba53138cb34f85f38c8080fd3815e" alt=""
この時作成する名前はViewControllerの名前と合わせてください。XibとViewControllerの名前が一致していないと後々面倒になります。
今回はHogeViewControllerというViewControllerのxibを用意するのでHogeViewController.xibと言う名前でxibファイルを作成します。
data:image/s3,"s3://crabby-images/abef3/abef35cb436f73b5f66fff76a7e5585cb547e363" alt=""
xibとviewControllerの紐付け
既存のViewControllerにXibを追加する際は紐付けが必要になります。
まずFile’s Ownerを設定します対応させたいViewControllerを❸の部分に書きます。
data:image/s3,"s3://crabby-images/bcf8c/bcf8c662079e501e2b490ea7022c133ae129c7f1" alt=""
次にFile’s OwnerとViewの紐付けを行います。
Control+クリックでFile’s OwnerとViewの接続を行います。
data:image/s3,"s3://crabby-images/afec9/afec9e4905575306e8c23643cb36aa83bcd24d6b" alt=""
接続できているかどうかはViewを右クリックで確認することができます。
接続できているとこんな感じになるはずです。
data:image/s3,"s3://crabby-images/6e3f0/6e3f01c2afa87906ff52461eb61ad0aa313a3154" alt=""
これで既存のviewControllerにxibを作成する手順が完了すあとは新規でXibを追加した時同様にレイアウトを組むことができます。
遷移時のinitializer
デフォルトのinitializerを使用する場合はXcodeがよしなにやってくれるので問題ありませんが、自作のinitializerを作成する場合はどのXibを使うのか指定が必要になります。
例としてTestViewControllerのinitializerを作成してみました。nibNameの部分にxibファイルの名前が入ります。
XibファイルとViewControllerの名前を統一した方が良いのはこのためです。
required initはStory boardから遷移した時に呼ばれるinitializerです。ないとXcodeに怒られますがStory Boardから遷移は使わないので初期状態のままで大丈夫です。
init() {
super.init(nibName: String(describing: TestViewController.self), bundle: nil)
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}