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

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

新規登録して質問してみよう
ただいま回答率
87.20%
Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

解決済

【Swift】collectionViewでボタンを押した時に選択したセルのテキストを変更したい

take.sakaguchi
take.sakaguchi

総合スコア11

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

1回答

0評価

0クリップ

4600閲覧

投稿2019/06/02 04:51

前提・実現したいこと

以下の写真のようなcollectionViewのセルの内容をボタンを押して変更できるようにしたいです。
具体的にはセルを選択している状態で画面下部のButtonを押すと、選択中セル内の”Label”部分が”ラベル”に変わるというようなプログラムを書きたいです。
イメージ説明

発生している問題・エラーメッセージ

様々な情報を探して読んでいますが、今回のようなボタンを押してセルの内容を変更するサンプルが見つからず、どうにもならないのが現状です。
全てのセルの”Label”部をボタンで一気に変更することはできましたが、選択しているセルのみを変更しようと色々試していたところ、それも再現できなくなってしまいました。
どうかアドバイス宜しくお願い致します。

該当のソースコード

Swift

import UIKit class ViewController: UIViewController, UICollectionViewDataSource, UICollectionViewDelegate { var indexNum = 0 @IBOutlet weak var collectionView: UICollectionView! override func viewDidLoad() { super.viewDidLoad() // レイアウトを調整 let layout = UICollectionViewFlowLayout() layout.sectionInset = UIEdgeInsets(top: 15, left: 15, bottom: 15, right: 15) collectionView.collectionViewLayout = layout } func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { if let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as? CollectionViewCell { cell.textLabel.text = String(indexPath.row) cell.textLabel.textColor = .black //タップしたcellの背景色 let selectedBGView = UIView(frame: cell.frame) selectedBGView.backgroundColor = .blue cell.selectedBackgroundView = selectedBGView cell.backgroundColor = .gray // セルの色 return cell } return UICollectionViewCell() } func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { return 18 // 表示するセルの数 } func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize { let horizontalSpace : CGFloat = 20 let cellSize : CGFloat = self.view.bounds.width / 3 - horizontalSpace return CGSize(width: cellSize, height: cellSize) } func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath){ indexNum = indexPath.row print(indexNum) } @IBAction func btn1(_ sender: UIButton) { } }

Swift

import UIKit class CollectionViewCell: UICollectionViewCell { @IBOutlet weak var textLabel: UILabel! // 左上テキスト 数字 @IBOutlet weak var subText: UILabel! // 下テキスト Label override func awakeFromNib() { super.awakeFromNib() } }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています