data:image/s3,"s3://crabby-images/f6327/f63271ae8ac6e4f10027499e9f106361974f92ef" alt="見出し画像"
【徒然iOS】気ままにUIKit26〜UITableView編集モード〜
概要
このマガジンは四十を過ぎたおっさんが、
を参考にStoryboardでiOSアプリを完全に趣味で楽しんでいるだけな記事を気ままに上げてます。
今回
をやる〜〜〜!
前準備
念の為、バックアップ
新しいクラス
ビューコントローラの追加
イニシャルビューの変更
をいつも通りやってから本題へ💃
data:image/s3,"s3://crabby-images/07d0d/07d0dbe8643268f00be25a3b17e33caf5509158a" alt=""
本題の前に、、、
だいぶビューの数も増えてきて横に長くなってきたから、
今までに作ったビューを
data:image/s3,"s3://crabby-images/32567/32567d7b01ada6ca46a05c6882d8f00c683d6224" alt=""
な感じで見やすく整理した〜〜〜!
後からSegueなんかでビューを繋いでいく時にこうやっておくと繋ぎやすくなるので💦
では、
本題
⒈テーブルビューを配置し、dataSource、delegate
data:image/s3,"s3://crabby-images/85fdf/85fdf137ee8616b800f854499b70441bd4db83cb" alt=""
data:image/s3,"s3://crabby-images/79ae2/79ae2f6d54672be057cb33312d203926f97b3718" alt=""
⒉Prototype Cellsを1に変更
data:image/s3,"s3://crabby-images/e2cc7/e2cc7f5f11a39d9c4d00b46cb98034b25572131d" alt=""
⒊Table View Cellをクリックし、IdentifierにCellの名前を入力
data:image/s3,"s3://crabby-images/1fc11/1fc11800b00889c9a67e9c9de6622d04b39e704f" alt=""
⒋切り替え用のボタンを配置
data:image/s3,"s3://crabby-images/e1e2a/e1e2a848e9c3dc891368b0588b58eae8319f978b" alt=""
data:image/s3,"s3://crabby-images/cd85c/cd85c00d48377df8578aa03c582a51eaf0ebb2b9" alt=""
⒌アシスタントを開いて、各パーツを接続
ボタン:changeModeButtonって名前でアクション接続
テーブルビュー:editableTableViewて名前でアウトレット接続
data:image/s3,"s3://crabby-images/248f4/248f4a372fc4fedb6dfa93dc69084059c2c8eaf4" alt=""
data:image/s3,"s3://crabby-images/acb93/acb93adcd3a246d2d2b9cd500aff45a9c5b17502" alt=""
data:image/s3,"s3://crabby-images/9c35d/9c35d26444f52628994b1c8bc97462f4b861b5ce" alt=""
⒍コードを追加
今回追加する箇所は
//データ
var dataList = ["青山","阿部","加藤","神田","佐藤","坂田"]
//データを返すメソッド
func tableView(tableView:UITableView, cellForRowAtIndexPath indexPath:NSIndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCellWithIdentifier("TestCell", forIndexPath:indexPath) as UITableViewCell
cell.textLabel?.text = dataList[indexPath.row]
return cell
}
//データの個数を返すメソッド
func tableView(tableView:UITableView, numberOfRowsInSection section:Int) -> Int {
return dataList.count
}
//ボタン押下時に呼ばれるメソッド
@IBAction func changeMode(sender: AnyObject) {
//通常モードと編集モードを切り替える。
if(testTableView.editing == true) {
testTableView.editing = false
} else {
testTableView.editing = true
}
}
だけど、先にいつものように
UITableViewDataSourceプロトコル
をクラスに追加して、stubsを追加しておこう
data:image/s3,"s3://crabby-images/9d91e/9d91e08b33d643991861d259fab703b9bf9e455e" alt=""
data:image/s3,"s3://crabby-images/3b510/3b5102fdeaaff407812ad494282a4c84bcbf9363" alt=""
data:image/s3,"s3://crabby-images/f81e9/f81e97317c71b8af290482440211472e0ff730f4" alt=""
では、コードを直してく〜〜〜
コードのTestCellとかテーブルビュー名だけを今回の名前に変更して
組み込むと、
data:image/s3,"s3://crabby-images/c0751/c0751b1c7b433e48c1b81726a7e3e2379f095bdc" alt=""
下のエラーはいつも通り
data:image/s3,"s3://crabby-images/ea578/ea578d29d85d05ea9b884b85f3b7774439ce3201" alt=""
data:image/s3,"s3://crabby-images/21a32/21a32b655ca45f81d8bc5346467f87e19ee664b9" alt=""
上のエラーは、、、
data:image/s3,"s3://crabby-images/3a081/3a081bb80d659525cce3caf26f348b20e48b8dac" alt=""
data:image/s3,"s3://crabby-images/02451/02451ad9eecb45f2485b78f4a429c67818164486" alt=""
data:image/s3,"s3://crabby-images/344f1/344f1d59365b0fce45eb8163714309b3fc725a8e" alt=""
⒎シミュレータで実行
data:image/s3,"s3://crabby-images/b0af4/b0af4d420cf32c1a82099d4203ef204654d25f7a" alt=""
data:image/s3,"s3://crabby-images/e11b4/e11b4aec10b86c7debf14fe977c221aec66a5f85" alt=""
⒏データ削除など、他のメソッドを追加
・データ削除
//テーブルビュー編集時に呼ばれるメソッド
func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) {
//削除の場合、配列からデータを削除する。
if( editingStyle == UITableViewCellEditingStyle.Delete) {
dataList.removeAtIndex(indexPath.row)
}
//テーブルの再読み込み
tableView.reloadData()
}
data:image/s3,"s3://crabby-images/71568/71568723cbd458aca189d080db88b5e7a4518791" alt=""
一個一個また直す
data:image/s3,"s3://crabby-images/13315/133159ace507aac73d2ab7dade9bf37201b8d3e9" alt=""
data:image/s3,"s3://crabby-images/41783/4178387a63c96b8bd9dc12b0c9c6d7730f7a9826" alt=""
data:image/s3,"s3://crabby-images/efa24/efa2431464296f86c80b2b3008168001c52a0fc0" alt=""
data:image/s3,"s3://crabby-images/d8b47/d8b47eef663ba0b1c70ecc9218e481be90fe869c" alt=""
data:image/s3,"s3://crabby-images/28f29/28f297663db9dfb50004ec4047fe9297b45c1920" alt=""
data:image/s3,"s3://crabby-images/ca262/ca26221c164b411d35a95b89922d3cdc623d9a62" alt=""
下の処理のところは、エラー内容が
Value of type '[String]' has no member 'removeAtIndex'
そんな処理いないよ
ってことみたいだから
//変更前
dataList.removeAtIndex(indexPath.row)
//変更後
dataList.remove(at: indexPath.row)
に書き換えると、
data:image/s3,"s3://crabby-images/b7fad/b7fad70c7e3a9fa25193d5d4190a131c9047265d" alt=""
シミュレータで実行
data:image/s3,"s3://crabby-images/5da3b/5da3b3cd68b2599d5d6a3b877b06861aeefef777" alt=""
と、実は理由は簡単で、
上の黄色エラーのFIXがPrivateに書き換えているだけで間違っているから〜〜〜
なので、JumptoDefinitionで現在の仕様を確認
data:image/s3,"s3://crabby-images/c14af/c14afa06da5ad3eae2081c9c41aeae7a7cbef92e" alt=""
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath)
に書き換えよう
data:image/s3,"s3://crabby-images/15001/15001b564f6c5b94d3cb548a314bbb1e32f4f084" alt=""
再実行すると、、、
data:image/s3,"s3://crabby-images/789fc/789fcc879a11d4a813f956977caee39084097438" alt=""
とまあ、後の要領は大体同じかな
data:image/s3,"s3://crabby-images/f1386/f138696e1cc7530e1f334032c2ccd545da860127" alt=""
data:image/s3,"s3://crabby-images/e3ca0/e3ca038e947a90737dd92e3af1c9b547940c4954" alt=""
data:image/s3,"s3://crabby-images/b081f/b081f1fb3586a140089c62d6bc6aa8c368732d28" alt=""
編集モードでデータを選択できるようにする
をやって
data:image/s3,"s3://crabby-images/406ef/406ef33f738d153907811012e6ea051f5b94f08c" alt=""
data:image/s3,"s3://crabby-images/14f16/14f1634d3cbcbe6ac33cfd1380e10789cf12e257" alt=""
リンク先の記事は以上。
*ここまでのコード
class TableEditModeViewController: UIViewController, UITableViewDataSource {
//データ
var dataList = ["青山","阿部","加藤","神田","佐藤","坂田"]
@IBAction func changeModeButton(_ sender: UIButton) {
//通常モードと編集モードを切り替える。
if(editableTableView.isEditing == true) {
editableTableView.isEditing = false
} else {
editableTableView.isEditing = true
}
}
@IBOutlet weak var editableTableView: UITableView!
//データの個数を返すメソッド
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return dataList.count
}
//データを返すメソッド
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCell(withIdentifier: "EditCell", for:indexPath) as UITableViewCell
cell.textLabel?.text = dataList[indexPath.row]
return cell
}
//テーブルビュー編集時に呼ばれるメソッド
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {
//削除の場合、配列からデータを削除する。
if( editingStyle == UITableViewCell.EditingStyle.delete) {
dataList.remove(at: indexPath.row)
}
//テーブルの再読み込み
tableView.reloadData()
}
//編集可否を答えるメソッド:下の並び替え可否を答えるメソッドと競合するのでいずれかのみ
func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
//最初の2行は削除不可にする。
if(indexPath.row < 2) {
return false
} else {
return true
}
}
//並び替え時に呼ばれるメソッド
func tableView(_ tableView: UITableView, moveRowAt sourceIndexPath: IndexPath, to destinationIndexPath: IndexPath){
//移動されたデータを取得する。
let moveData = tableView.cellForRow(at: sourceIndexPath as IndexPath)?.textLabel!.text
//元の位置のデータを配列から削除する。
dataList.remove(at: sourceIndexPath.row)
//移動先の位置にデータを配列に挿入する。
dataList.insert(moveData!, at: destinationIndexPath.row)
}
//並び替え可否を答えるメソッド:上の編集可否を答えるメソッドと競合するのでいずれかのみ
func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
let orderData = dataList[indexPath.row]
//青山さん以外の行は並び替え不可にする。
if(orderData != "青山") {
return false
} else {
return true
}
}
override func viewDidLoad() {
super.viewDidLoad()
}
}
ブラッシュアップ
ここからブラッシュアップ
⒈ボタンの表示名を編集onとoffで切り替えたい
・ボタンをアウトレットでも接続後、コードを以下に追記変更
class TableEditModeViewController: UIViewController, UITableViewDataSource {
//データ
@IBOutlet weak var editButton: UIButton!//アウトレット接続
var dataList = ["青山","阿部","加藤","神田","佐藤","坂田"]
@IBAction func changeModeButton(_ sender: UIButton) {
//通常モードと編集モードを切り替える。
if(editableTableView.isEditing == true) {
editableTableView.isEditing = false
editButton.setTitle("編集on", for: .normal)//追加
} else {
editableTableView.isEditing = true
editButton.setTitle("編集off", for: .normal)//追加
}
}
@IBOutlet weak var editableTableView: UITableView!
//データの個数を返すメソッド
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return dataList.count
}
//データを返すメソッド
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
//セルを取得する。
let cell = tableView.dequeueReusableCell(withIdentifier: "EditCell", for:indexPath) as UITableViewCell
cell.textLabel?.text = dataList[indexPath.row]
return cell
}
//テーブルビュー編集時に呼ばれるメソッド
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {
//削除の場合、配列からデータを削除する。
if( editingStyle == UITableViewCell.EditingStyle.delete) {
dataList.remove(at: indexPath.row)
}
//テーブルの再読み込み
tableView.reloadData()
}
//編集可否を答えるメソッド:下の並び替え可否を答えるメソッドと競合するのでいずれかのみ
func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
//最初の2行は削除不可にする。
if(indexPath.row < 2) {
return false
} else {
return true
}
}
//並び替え時に呼ばれるメソッド
func tableView(_ tableView: UITableView, moveRowAt sourceIndexPath: IndexPath, to destinationIndexPath: IndexPath){
//移動されたデータを取得する。
let moveData = tableView.cellForRow(at: sourceIndexPath as IndexPath)?.textLabel!.text
//元の位置のデータを配列から削除する。
dataList.remove(at: sourceIndexPath.row)
//移動先の位置にデータを配列に挿入する。
dataList.insert(moveData!, at: destinationIndexPath.row)
}
//並び替え可否を答えるメソッド:上の編集可否を答えるメソッドと競合するのでいずれかのみ
func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
let orderData = dataList[indexPath.row]
//青山さん以外の行は並び替え不可にする。
if(orderData != "青山") {
return false
} else {
return true
}
}
override func viewDidLoad() {
super.viewDidLoad()
editButton.setTitle("編集on", for: .normal)//追加
}
}
シミュレータを実行すると
data:image/s3,"s3://crabby-images/48619/486190600c508569b646a96524fc085886fd9e29" alt=""
data:image/s3,"s3://crabby-images/a488e/a488e4da9786f6ee81940f7fb0cd8e2c3aadeeb3" alt=""
⒉AutoLayoutの制約を追加
あとは、いつもどおり
data:image/s3,"s3://crabby-images/3669c/3669c8f086e511aeba3580cd3be3dcc61ee9df04" alt=""
data:image/s3,"s3://crabby-images/5c4c4/5c4c48d37e8b48c27f842a86f936711088279216" alt=""
data:image/s3,"s3://crabby-images/d9090/d909077f532642e11d9654f959dc542f84f4f6d2" alt=""
以上です〜〜〜〜!🕺
まとめ
これであとは、データベース機能と連携して編集後のテーブルの状態を保存するかどうかで、よく目にするテーブルアプリのイメージが湧くかな💦
Apple公式
さて、次回は
をやる予定。
あんまり使ったことないな💦