UITableViewControllerを使うと嬉しいこと
2つのメリット
-
Static Cell
が使えること - 入力欄をタップしてキーボードが表示された際、入力欄が隠れないよう、自動的にスクロールしてくれる点
Static Cellって?
- 静的にセクションやセルの数を指定するもの
- 設定画面など、単純なTableViewを使った画面を作りたいときに、サクッと作れて便利
- 普通の
UITableView
ではStatic Cell
は使えず、指定してもコンパイルエラーになる
入力欄のスクロール制御
-
UIScrollView
の中に入力欄を設置した場合、キーボードが表示されてもスクロール制御はされず、入力欄が隠れてしまうことがある- 入力欄が隠れないようにするためには、コード側でちょっとややこしいスクロール制御を加える必要がある
data:image/s3,"s3://crabby-images/63174/63174490dabc06110cc3edb4f28baada126741b4" alt="Simulator Screen Shot - iPhone SE - 2018-07-06 at 06.10.03.png"
data:image/s3,"s3://crabby-images/97a15/97a150c1283cdb72d3f6793ab2edff37f8b41c3b" alt="Simulator Screen Shot - iPhone SE - 2018-07-06 at 06.10.17.png"
-
UITableViewController
の中に入力欄を設置した場合、キーボードを開いても入力欄が隠れないように自動制御してくれるため、コード側での指定が不要で、とても簡単
data:image/s3,"s3://crabby-images/63174/63174490dabc06110cc3edb4f28baada126741b4" alt="Simulator Screen Shot - iPhone SE - 2018-07-06 at 06.10.03.png"
data:image/s3,"s3://crabby-images/1b423/1b423cda31da5654be0e193affebe42861512961" alt="Simulator Screen Shot - iPhone SE - 2018-07-06 at 06.10.12.png"
Static Cell を使った入力画面の作成手順
準備
- プロジェクトを
Single View App
で作成 -
ViewController.swift
のUIViewController
をUITableViewController
に変更
import UIKit
class ViewController: UITableViewController {
override func viewDidLoad() {
super.viewDidLoad()
}
}
Main.storyboard
- Storyboard上に
Table View Controller
を設置
data:image/s3,"s3://crabby-images/27aa5/27aa597761a1f04930e0a0d52e7a4c93ab2c0667" alt="スクリーンショット 2018-07-06 6.36.05.png"
-
Storyboard Entry Point
を追加したTable View Controller
に変更 -
Identify Inspector
パネルのCustom Class
>Class
欄に、ViewController
を入力
data:image/s3,"s3://crabby-images/b25a0/b25a0294bfb90c548ec116ef0749c4333b757b22" alt="スクリーンショット 2018-07-06 6.35.20.png"
-
Attributes Inspector
パネルの最上部にあるContent
をStatic Cell
に変更
data:image/s3,"s3://crabby-images/9443d/9443dc1d7ad33fa99a7e8f2bac58a79859581144" alt="スクリーンショット 2018-07-06 5.27.11.png"
-
Sections
の部分で、必要なセクション数に変更 (今回は5
)
data:image/s3,"s3://crabby-images/4ad4a/4ad4ad8673ef10480751fc130077f400f1558730" alt="スクリーンショット 2018-07-06 6.37.51.png"
data:image/s3,"s3://crabby-images/a3cd4/a3cd45bb49d4492cad6c587b70869083cc84123a" alt="スクリーンショット 2018-07-06 5.38.56.png"
data:image/s3,"s3://crabby-images/10176/1017647a44511518035111d6c263458201da94e6" alt="スクリーンショット 2018-07-06 6.39.29.png"
-
Table View Cell
の中にText Field
を設置し、上下左右にConstraints
を加える (今回は全て0
)
data:image/s3,"s3://crabby-images/bd4bb/bd4bbef86a5fb923f8b73c6f21ec2b0130b45509" alt="スクリーンショット 2018-07-06 6.08.59.png"
data:image/s3,"s3://crabby-images/63174/63174490dabc06110cc3edb4f28baada126741b4" alt="Simulator Screen Shot - iPhone SE - 2018-07-06 at 06.10.03.png"
備考
最初から UITableViewController でswiftファイルを作成した場合
- Static Cell にすることで不要となる
numberOfSections(in tableView: UITableView)
とtableView(_ tableView: UITableView, numberOfRowsInSection section: Int)
を削除
data:image/s3,"s3://crabby-images/91e08/91e088e97b201372b2323741370e0ee18c3625d2" alt="スクリーンショット 2018-07-06 5.55.41.png"
環境
- Xcode Version 9.4.1