質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Xcode 7

Xcode 7は、ソフトウェア開発のためのアップルの統合開発環境であるXcodeのバージョン。UIを作成するために用いるグラフィカルツールです。iOS9/OS X El Capitan/watchOS2に対応。Swift 2コンパイラーが搭載されています。

Swift 2

Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

Q&A

解決済

1回答

5260閲覧

tableViewの特定のセルを非表示にしたい

M.minoru

総合スコア19

Xcode 7

Xcode 7は、ソフトウェア開発のためのアップルの統合開発環境であるXcodeのバージョン。UIを作成するために用いるグラフィカルツールです。iOS9/OS X El Capitan/watchOS2に対応。Swift 2コンパイラーが搭載されています。

Swift 2

Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

0グッド

0クリップ

投稿2016/08/24 02:45

編集2016/08/24 05:07

tableViewの特定のセルを非表示にしたいです。
例えば以下の添付画像のページを開いた時に、Aのセルを非表示にしてみる。buttonを押すとBのセルが非表示になるといった感じです。

またもう一度buttonを押すとBのセルが再表示されるなども行なえる機能も欲しいと思っています。

tableviewcell 追加などで検索してみてもセルの行数に応じて可変にする、一括で表示を変更する、objective-cのコードで何をしているか分からないなどでよくわからず、手元の本にはtableviewcellの設定などについては詳しく載っていませんでした

import UIKit class TableViewController: UITableViewController { override func viewDidLoad() { super.viewDidLoad() } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } }

イメージ説明

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

非表示ということはできないのでセルから削除することになると思います。

とりあえず以下のコードでStoryboardを設定すると、ボタン押下でセルがアニメーションして削除されます。
※ 削除されたセルはボタンが見えないので再度押下して表示することはできません、このところはどのように考えていますか?

swift

1import UIKit 2 3class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, CustomCellDelegate { 4 5 @IBOutlet weak var tableView: UITableView! 6 7 // Section Data 8 let sectionTitleArray = ["Section-1", "Section-2", "Section-3"] 9 10 // Data Array 11 var dataArray1 = [Model("A"), Model("B"), Model("C", isShowButton: true), Model("D"), Model("E")] 12 var dataArray2 = [Model("1"), Model("2"), Model("3")] 13 var dataArray3 = [Model("a"),Model("b"),Model("c"),Model("d")] 14 var dataArrayGroup: [[Model]] = [] 15 16 override func viewDidLoad() { 17 super.viewDidLoad() 18 19 20 // Make Data 21 dataArrayGroup.append(dataArray1) 22 dataArrayGroup.append(dataArray2) 23 dataArrayGroup.append(dataArray3) 24 25 tableView.estimatedRowHeight = 20 26 tableView.rowHeight = UITableViewAutomaticDimension 27 } 28 29 30 // MARK: - TableView Delegate & DataSource 31 32 func tableView(tableView: UITableView, titleForHeaderInSection section: Int) -> String? { 33 return sectionTitleArray[section] 34 } 35 36 // Section Count 37 func numberOfSectionsInTableView(tableView: UITableView) -> Int { 38 return dataArrayGroup.count 39 } 40 41 // Row Count 42 func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 43 return dataArrayGroup[section].count 44 } 45 46 47 // Generate Cell 48 func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { 49 let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! CustomCell 50 cell.textLabel?.text = dataArrayGroup[indexPath.section][indexPath.row].text 51 cell.closeButton.hidden = !dataArrayGroup[indexPath.section][indexPath.row].isShowButton 52 cell.delegate = self 53 cell.cellIndexPath = indexPath 54 cell.textLabel?.backgroundColor = UIColor.clearColor() 55 return cell 56 } 57 58 func pushDeleteAction(indexPath: NSIndexPath) { 59 dataArrayGroup[indexPath.section].removeAtIndex(indexPath.row) 60 tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Automatic) 61 } 62} 63 64struct Model { 65 var text = "" 66 var isShowButton = false 67 68 init(_ text: String, isShowButton: Bool = false) { 69 self.text = text 70 self.isShowButton = isShowButton 71 } 72} 73 74protocol CustomCellDelegate: class { 75 func pushDeleteAction(indexPath: NSIndexPath) 76} 77 78 79class CustomCell: UITableViewCell { 80 81 var cellIndexPath: NSIndexPath! 82 weak var delegate: CustomCellDelegate! 83 @IBOutlet weak var closeButton: UIButton! 84 85 @IBAction func pushCloseButton(sender: UIButton) { 86 delegate?.pushDeleteAction(cellIndexPath) 87 } 88}

回答追記 サンプル

teratail_45367 サンプル
中にプロジェクトが2つ入っていてteratail_45367-1の方がデータを削除、追加しているものでteratail_45367-2がセルの高さを変更しているものです。

参考にしてみてください。

投稿2016/08/24 04:22

編集2016/08/24 21:47
_Kentarou

総合スコア8490

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

M.minoru

2016/08/24 05:11

回答ありがとうございます ーーーーーー ※ 削除されたセルはボタンが見えないので再度押下して表示することはできません、このところはどのように考えていますか? ーーーーーー こちらについてはボタンの配置してあるセル自体は消さず、そのセルの下のセルを非表示にしたり、再表示にしたりできればと考えています。 回答のコードですがstoryboadで作成した私の書き方と違うのでどのように使えばいいのかわかりませんでした。
_Kentarou

2016/08/24 20:25 編集

やりたいことが少し分かったのでサンプルを作りました、回答に追記したのでダウンロードして試してみてください。
M.minoru

2016/08/25 01:00

ありがとうございます 実行してみたらまさにやってみたかったことでした。 わざわざコードを書いていただきありがとうございます。 コードも見やすいので読んで理解して自分のプログラグでも再現できるように頑張ります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問