【Swift4】xibファイルでViewを作成してStoryboardで使用する方法
xibファイルでUIViewを作成し、Storyboardで再利用できる部品となるクラスファイルを作成する方法です。
実装手順
1.カスタムクラス(swiftファイル)とxibファイルを作って紐づける
2.xibファイルに紐づけたカスタム(swiftファイル)にxibファイルを読み込むコードを記述する
3.Storyboardでxibに紐づけたカスタムクラスを配置する
1. カスタムクラス(swiftファイル)とxibファイルを作って紐づける
1-1. カスタムクラス(swiftファイル)を作る
data:image/s3,"s3://crabby-images/b6d36/b6d36e14b2c79f5cda646c1440f5b888b581b4cc" alt=""
xibファイルと紐づけるカスタムクラス(swiftファイル)を作成していきます。
今回はUIViewクラスを継承した「XibView」というクラス名で作成してきます。
1-2. xibファイルを作る
data:image/s3,"s3://crabby-images/98a1f/98a1fe43e62eff501a893ae485117c403626d8d0" alt=""
data:image/s3,"s3://crabby-images/00e1d/00e1d5447b39ae1dac3965bc4d562b14283aac48" alt=""
カスタムクラス(swiftファイル)と紐づけるxibファイルを作成していきます。
今回はカスタムクラスを「XibView」というクラス名で作成したので、xibファイル名もわかりやすく「XibView」という名前で作成してきます。
これで「XibView.swift」と「XibView.xib」ができました。
1-3. カスタムクラス(swiftファイル)とxibファイルを紐づける
data:image/s3,"s3://crabby-images/f7613/f7613d2d224d7784635996849d2b0ab40466c9eb" alt=""
xibファイルのFile's OwnerのCustom Classに「XibView」を設定します。
1-4. xibファイルの中身を配置
data:image/s3,"s3://crabby-images/3df44/3df44a93b13be532d315f6d0d4caad039eac7cef" alt=""
今回は以下の設定のみを行なっています。
・Viewの背景を赤色に変更
・UILabelを追加して「XibView」というタイトルに変更
・UILabelの文字をセンタリング(中央寄せ)する
・UILabelのAoutLayoutを設定する
data:image/s3,"s3://crabby-images/2c67f/2c67f3112887c76d49cab0166024b4452dcf9ab0" alt=""
UILabelのAoutLayoutはこのように設定しました。
2. xibファイルに紐づけたカスタム(swiftファイル)にxibファイルを読み込むコードを記述する
import UIKit
class XibView: UIView {
// コードから生成した時の初期化処理
override init(frame: CGRect) {
super.init(frame: frame)
self.nibInit()
}
// ストーリーボードで配置した時の初期化処理
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
self.nibInit()
}
// xibファイルを読み込んでviewに重ねる
fileprivate func nibInit() {
// File's OwnerをXibViewにしたので ownerはself になる
guard let view = UINib(nibName: "XibView", bundle: nil).instantiate(withOwner: self, options: nil).first as? UIView else {
return
}
view.frame = self.bounds
view.autoresizingMask = [.flexibleHeight, .flexibleWidth]
self.addSubview(view)
}
}
コードで生成した場合も、Storybboard上で作成した場もxibファイルが読み込まれるようにプログラムします。
3. Storyboardでxibに紐づけたカスタムクラスを配置する
data:image/s3,"s3://crabby-images/5dccb/5dccb792b94dfd0f3d5e1af11e8320f28f7a9fd4" alt=""
最後にxibファイルを配置したいStoryboardで、UIViewを配置した後に配置したUIViewのCustom Classを「XibView」に変更すれば設定完了です。
おまけ. 再利用できる部品となっているか確認
data:image/s3,"s3://crabby-images/1cb6d/1cb6df81783193ee7cfd358ed4937d9d48a037df" alt=""
xibファイルを3つサイズをバラバラにして配置してみました。
data:image/s3,"s3://crabby-images/5db67/5db6775d40aaa937de42dbbd86ab0357f0814bd5" alt=""
実行結果はこのようになります。
ちゃんとオートレイアウトも効いていますね!