data:image/s3,"s3://crabby-images/a86e8/a86e8259a91a25aa90c5d0e84041f2b28a1878b8" alt="見出し画像"
【徒然iOS】気ままにUIKit23〜TableViewCellのStyle設定〜
概要
このマガジンは四十を過ぎたおっさんが、
を参考にStoryboardでiOSアプリを完全に趣味で楽しんでいるだけな記事を気ままに上げてます。
今回
を前回に引き続き、Style以降をやる〜〜〜〜!
前準備
念の為、バックアップ
新しいクラス
ビューコントローラの追加
イニシャルビューの変更
をいつも通りやってから本題へ💃
data:image/s3,"s3://crabby-images/e8b86/e8b86b1a44c2356cbc0485ee667076a6bbfac515" alt=""
本題の前に、、、
Styleのコード
//
// テーブルビューにタイトルと詳細を表示する。
//
import UIKit
class ViewController: UIViewController,UITableViewDataSource {
@IBOutlet weak var testTableView: UITableView!
//データ
var dataList = ["青山,一塁手","阿部,捕手","加藤,二塁手","神田,三塁手","佐藤,遊撃手","坂田,外野手"]
//データを返すメソッド
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCellWithIdentifier("TestCell", forIndexPath:indexPath) as UITableViewCell
//データをカンマで分割する。
let arr = dataList[indexPath.row].componentsSeparatedByString(",")
cell.textLabel?.text = arr[0] //タイトル
cell.detailTextLabel?.text = arr[1] //詳細文
return cell
}
//データの個数を返すメソッド
func tableView(tableView:UITableView, numberOfRowsInSection section:Int) -> Int {
return dataList.count
}
//最初からあるメソッド
override func viewDidLoad() {
super.viewDidLoad()
}
}
のコードを今回は追加するんだけど、その一個前のコード全文だと、、、、
一個前のコード
//
// セルの背景を縞模様にしながらテーブルビューにデータを表示
//
import UIKit
class ViewController: UIViewController,UITableViewDataSource {
@IBOutlet weak var testTableView: UITableView!
//データ
var dataList = ["青山","阿部","加藤","川島","神田","佐藤","坂田","田中"]
//データを返す
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) -> UITableViewCell {
let cellName:String
//偶数行と奇数行で原型セルを変更する。
if (indexPath.row % 2 == 0) {
cellName = "TestCell1"
} else {
cellName = "TestCell2"
}
let cell = tableView.dequeueReusableCellWithIdentifier(cellName, forIndexPath:indexPath) as UITableViewCell
cell.textLabel?.text = dataList[indexPath.row]
return cell
}
//データの個数を返す
func tableView(tableView:UITableView, numberOfRowsInSection section:Int) -> Int {
return dataList.count
}
//最初からあるメソッド
override func viewDidLoad() {
super.viewDidLoad()
}
}
セル自体が、
let cell = tableView.dequeueReusableCellWithIdentifier("TestCell", forIndexPath:indexPath) as UITableViewCell
で
CellNameがTestCellに急に変わってる👀
このTestCellはどこから来たのかが不明💦
👉慎重に、バックアップを取って、ビューを追加して、前回、前々回までにやったTableView→dataSourceに連携→TableCellViewを追加しての手順までをやってから、やった方がいいと判断した次第。
では早速
⒈TableView→dataSourceに連携→TableCellViewを追加
data:image/s3,"s3://crabby-images/f79d7/f79d76ccb6fe5fce4538d935d8960221cf35673d" alt=""
⒉StyleをRight Detailに設定
なんか、それっぽくなってきたね👀
data:image/s3,"s3://crabby-images/68fd3/68fd35757a7dec1496bf2965d7af3d13fc907c8b" alt=""
⒊コードを追加する前にコードを見ると、、、
//
// テーブルビューにタイトルと詳細を表示する。
//
import UIKit
class ViewController: UIViewController,UITableViewDataSource {
@IBOutlet weak var testTableView: UITableView!
//データ
var dataList = ["青山,一塁手","阿部,捕手","加藤,二塁手","神田,三塁手","佐藤,遊撃手","坂田,外野手"]
//データを返すメソッド
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCellWithIdentifier("TestCell", forIndexPath:indexPath) as UITableViewCell
//データをカンマで分割する。
let arr = dataList[indexPath.row].componentsSeparatedByString(",")
cell.textLabel?.text = arr[0] //タイトル
cell.detailTextLabel?.text = arr[1] //詳細文
return cell
}
//データの個数を返すメソッド
func tableView(tableView:UITableView, numberOfRowsInSection section:Int) -> Int {
return dataList.count
}
//最初からあるメソッド
override func viewDidLoad() {
super.viewDidLoad()
}
}
上から6行目あたりにテーブルビューをアウトレット接続してることがわかる👀
なので、アウトレット接続をしておく
data:image/s3,"s3://crabby-images/12de6/12de633676aec5b61b17d45cb2d54792207f384a" alt=""
⒋コードを追加
先に、UITableViewDataSourceプロトコルを追加
data:image/s3,"s3://crabby-images/78348/78348dede24aedc46605425bf01e39879aface33" alt=""
ここで追加するコード
//データ
var dataList = ["青山,一塁手","阿部,捕手","加藤,二塁手","神田,三塁手","佐藤,遊撃手","坂田,外野手"]
//データを返すメソッド
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCellWithIdentifier("TestCell", forIndexPath:indexPath) as UITableViewCell
//データをカンマで分割する。
let arr = dataList[indexPath.row].componentsSeparatedByString(",")
cell.textLabel?.text = arr[0] //タイトル
cell.detailTextLabel?.text = arr[1] //詳細文
return cell
}
//データの個数を返すメソッド
func tableView(tableView:UITableView, numberOfRowsInSection section:Int) -> Int {
return dataList.count
}
ベタで貼ると、こんな感じでエラー発生
data:image/s3,"s3://crabby-images/12f6c/12f6cf141c8bed2446427020f782e4de90925ddd" alt=""
上のエラーをFIXする
data:image/s3,"s3://crabby-images/e3b7a/e3b7a8d99ab74ccaf1d2f2d170405a39df8a0bba" alt=""
data:image/s3,"s3://crabby-images/65eb7/65eb71a73076d5d76632b84957a8c2c1136ee937" alt=""
data:image/s3,"s3://crabby-images/2dff7/2dff7f4e9e5db3aa8ce561bfde24fca43c15fa6e" alt=""
中のエラーを直す
こちらはFIXなしエラーなので、おそらく完全に書き方が違うはず。
data:image/s3,"s3://crabby-images/8d18d/8d18d18ccc8ec00fc741faf3898d5c29265ea050" alt=""
こういう時は、
data:image/s3,"s3://crabby-images/24eff/24eff111f4e3f532192a9bf9cf125521b90afa5a" alt=""
data:image/s3,"s3://crabby-images/25358/25358cb260f95b20a7b3e286caf9f71812d122c5" alt=""
コピーした行を貼り付けて、.以降を一旦消して〜〜
.compを入力して出てくる候補からcomponent(separatedBy:)を選択して、
data:image/s3,"s3://crabby-images/bcd9e/bcd9e0d6efcd1d73fcfbeb24fbb24c91309cac0c" alt=""
data:image/s3,"s3://crabby-images/ed04a/ed04adee7fa3ea2a6442fd55e93665ebb0f02955" alt=""
あとは、一番下のエラーを修正
data:image/s3,"s3://crabby-images/ed3ff/ed3fff4cbf42b7bff87c0204d2d8cf4bcbe209e5" alt=""
data:image/s3,"s3://crabby-images/841db/841dbc7d59f3375a8673df5bf695b66b34398866" alt=""
まだstubsのエラーが出てるから、前回までと同様に直していく
⒌シミュレータ実行
data:image/s3,"s3://crabby-images/fd732/fd7325419c7559ea29ba6219762b3adc33228fb9" alt=""
ここまでのコード
class TableCellStyleViewController: UIViewController, UITableViewDataSource {
@IBOutlet weak var styleTableView: UITableView!
//データ
var dataList = ["青山,一塁手","阿部,捕手","加藤,二塁手","神田,三塁手","佐藤,遊撃手","坂田,外野手"]
//データを返すメソッド
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCell(withIdentifier: "StyleCell", for:indexPath as IndexPath) as UITableViewCell
//データをカンマで分割する。
let arr = dataList[indexPath.row].components(separatedBy: ",")
cell.textLabel?.text = arr[0] //タイトル
cell.detailTextLabel?.text = arr[1] //詳細文
return cell
}
//データの個数を返すメソッド
func tableView(_ tableView:UITableView, numberOfRowsInSection section:Int) -> Int {
return dataList.count
}
override func viewDidLoad() {
super.viewDidLoad()
}
}
バックアップを取って、設定をいじってみよう
data:image/s3,"s3://crabby-images/cc447/cc447c70e7575c292f0f407a2b3fc7d503b5e0d6" alt=""
data:image/s3,"s3://crabby-images/a77de/a77de307ecda91105f8c7f9be326b4346324a19b" alt=""
data:image/s3,"s3://crabby-images/32070/32070e31d117caf9c52cc8e888fc6dda4416e7d9" alt=""
カスタムはまたちょっと毛色が違うようなので、
一旦ここまでで
⒍ブラッシュアップ
今回はTableViewをAutoLayout制約をつけるくらいでいいかな
data:image/s3,"s3://crabby-images/45410/45410c6d2e4811f7f3545d292e352042bef846f6" alt=""
data:image/s3,"s3://crabby-images/aed30/aed30cfe878cc007760acc82df87c083c8627fa0" alt=""
data:image/s3,"s3://crabby-images/32550/3255005f6d7e20d66d24a9480e702c9bfa37e624" alt=""
まとめ
今回は、ここまで。
WEBリストで使うなあと
と思うってもらう程度いいかな🕺
昔、作って、今でも自分のスマホで愛用してるWEBリスト集
data:image/s3,"s3://crabby-images/43016/43016f189149ccebc1e9ed278d6775a678f0f4c3" alt=""
data:image/s3,"s3://crabby-images/64577/64577f60883e3c4329b949601ad8161f77ac4d1c" alt=""
data:image/s3,"s3://crabby-images/c6d50/c6d50e84d791d2fe75c1003b26029486c709a852" alt=""
まあ、これは他にも色々と設定が必要だから、
はじはじの制作体験記で必要なところを全部回せて機会があればやろうかな。
Apple公式
さてと、次回は
カスタムの続きからやる〜〜〜!