私は今まで使う機会がなかったのか、使いにくいのかわからないですが
UISegmented Controlを使ってませんでした。
data:image/s3,"s3://crabby-images/89f31/89f31c6b404f5bc2a2690d5cde75a23ad41ae414" alt=""
こんなやつです。
目次
UISegmented Controlの利点
このUISegmented Controlの使いやすい点として以下があります。
- 数を簡単に増やせる
- それぞれのセグメントにindex番号がある
さくっと複数のボタンを作れ押されたボタンによって
アクションを変えるのが非常に簡単です。
カスタムするには正直UIButtonのがいいような感じがしますが、
ここもさくっとご紹介します。
UIの作成
今回は簡易的なタブの作り方をご紹介します。
まずはプロジェクトを作成してMainStoryboardにUISegmented Controlを
置いてやってください。
data:image/s3,"s3://crabby-images/8188b/8188bc6bc85dd96eaab85588306ac20b19879411" alt=""
下の画像の様にUISegmented Control、UITableView, Cellを配置してください。
cellのidentifierの設定を忘れずに。。私はcellって名前にしました。
data:image/s3,"s3://crabby-images/38f26/38f26c4140bd3bf10122a3c0fe45fba92100072e" alt=""
こんな感じです。
UISegmented Controlの設定
(ここは飛ばしても構いません)
以下2点を変更していきます。
Segmentの数がデフォルトの2つではつまらないので3つにします。
それぞれのTitleもFirst、Secondでつまらないのでここも変更します。
data:image/s3,"s3://crabby-images/b9532/b95328b48c0ad3830273745fd800a33a835bd59a" alt=""
ざっくり赤い枠の中を変更していくと形が変更していきます。
Segmentの数
Segmentsというところを2->3に。
SegmentのTitle
Titleという箇所で変更できます。
Segmentというのをいじると別のSegmentを変更できます。
ここは任意で変更してみてください!
その後全てViewControllerに紐付けてください!
class ViewController: UIViewController {
@IBOutlet weak var segmentControl: UISegmentedControl!
@IBOutlet weak var tableView: UITableView!
@IBAction func selectedSegment(_ sender: UISegmentedControl) {
}
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
}
こんな感じになっていればいいかと思います。
UITableViewの表示の設定
表示の設定をサックとしていきます。
設定の仕方は
こちらの記事を参考にしていただければと思います。
data:image/s3,"s3://crabby-images/2da53/2da536e58d035d894ca63bf82056fb70894f9774" alt=""
class ViewController: UIViewController, UITableViewDataSource {
@IBOutlet weak var segmentControl: UISegmentedControl!
@IBOutlet weak var tableView: UITableView!
@IBAction func selectedSegment(_ sender: UISegmentedControl) {
}
override func viewDidLoad() {
super.viewDidLoad()
tableView.dataSource = self
// Do any additional setup after loading the view.
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 8
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
cell.textLabel?.text = "test"
return cell
}
}
ここまでで、一度ビルドしてみてください。
試しに入れたtestという文字のcellが出ていればここまでは順調です。
次がようやくUISegmented Controlの見せどころです。
Segmentをtapしたらそれぞれ文字を変更させます
cellの設定
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
//ここから追加
let segmentIndex = segmentControl.selectedSegmentIndex
switch segmentIndex {
case 0:
cell.textLabel?.text = segmentControl.titleForSegment(at: segmentIndex)
case 1:
cell.textLabel?.text = segmentControl.titleForSegment(at: segmentIndex)
case 2:
cell.textLabel?.text = segmentControl.titleForSegment(at: segmentIndex)
default:
return UITableViewCell()
}
return cell
////ここまで
}
segmentを選択した時にtableViewのリロード
@IBAction func selectedSegment(_ sender: UISegmentedControl) {
//////追加
tableView.reloadData()
//////
}
やってることを説明します!
- 選択されたSegmentによって表示の条件分岐をさせます
- cellのtextに先ほど任意で設定したそれぞれのSegmentのTitleにします
- 別のSegmentを触れた時、tableViewをリロードさせます
全体のコード
class ViewController: UIViewController, UITableViewDataSource {
@IBOutlet weak var segmentControl: UISegmentedControl!
@IBOutlet weak var tableView: UITableView!
@IBAction func selectedSegment(_ sender: UISegmentedControl) {
tableView.reloadData()
}
override func viewDidLoad() {
super.viewDidLoad()
tableView.dataSource = self
// Do any additional setup after loading the view.
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 8
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
let segmentIndex = segmentControl.selectedSegmentIndex
switch segmentIndex {
case 0:
cell.textLabel?.text = segmentControl.titleForSegment(at: segmentIndex)
case 1:
cell.textLabel?.text = segmentControl.titleForSegment(at: segmentIndex)
case 2:
cell.textLabel?.text = segmentControl.titleForSegment(at: segmentIndex)
default:
return UITableViewCell()
}
return cell
}
}
ビルド
data:image/s3,"s3://crabby-images/05067/050673dd044524cf8c49ec38c15edc7ae2c259c1" alt=""
data:image/s3,"s3://crabby-images/6fafa/6fafab6328e418175f52573c0fce71df0c188848" alt=""
data:image/s3,"s3://crabby-images/8d406/8d40663faf7977e83aee35f8326e1b32e3fe428d" alt=""
めっちゃ簡単ですね!
誰かこの記事をみていることを願い来週もまた書きます。
まさを。
data:image/s3,"s3://crabby-images/f5839/f583958244b4dc2bcd8a6202c1ae2a4acadfabc4" alt=""
- 無料・簡単・片手でホームページを作成できる自社サービス Rakwi
- Web制作とアプリ開発を学べるオンラインプログラミング講座 Upstairs
- 開発,DX推進支援サービス スタートアッププラン