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

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

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

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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

解決済

Table cell上にあるボタンのインデックスを、TableViewController上で宣言している変数に受け渡したい。

tasmicsy
tasmicsy

総合スコア13

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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

1回答

0評価

0クリップ

326閲覧

投稿2021/11/29 08:38

編集2021/11/30 01:51

やりたい事

下図にある通り、各質問(q.question[index.row]に対して5個の◯ボタンを配置し、選択されている●の値をq.answer[indexPath.row]に格納したいです。
◯ボタンが選択されて●になる毎に、QuizCellクラス内のcurrentQuizButtonIndexは更新されるようにはなっていますが、それをTableViewControllerにて宣言されている変数qの中に入れる方法がわかりません。
イメージ説明

特にわからないこと

TableViewCellで、対応するindexPath.rowを用いたいのですが、Cell.swiftでは使うことはできないのでしょうか。
何問目のどのボタンが押されたかをセーブしたいです。

各ソースコード

QuizCell

Swift

import UIKit import Foundation protocol QuizCellDelegate { func quizCellDidChangeCurrentButtonIndex(_ cell: QuizCell, index: Int) } class QuizCell: UITableViewCell { var currentQuizButtonIndex: Int = 0 { didSet { let value = self.currentQuizButtonIndex self.updateCurrentQuizButton(value) if let delegate = self.delegate { delegate.quizCellDidChangeCurrentButtonIndex(self, index: value) } } } @IBOutlet weak var questionLabel: UILabel! @IBOutlet var answerButtons: [UIButton]! var delegate: QuizCellDelegate? override func awakeFromNib() { super.awakeFromNib() //print("ここまできてるか確認") // Initialization code } @IBAction func didTapQuizButton(_ sender: UIButton) { if let index = self.answerButtons.firstIndex(of: sender){ self.currentQuizButtonIndex = index delegate?.quizCellDidChangeCurrentButtonIndex(self, index: index) print(index) } } private func updateCurrentQuizButton(_ currentIndex: Int){ for (index, answerButton) in self.answerButtons.enumerated(){ if index == currentIndex { answerButton.setTitle("●", for: .normal) } else { answerButton.setTitle("○", for: .normal) } } } override func setSelected(_ selected: Bool, animated: Bool) { super.setSelected(selected, animated: animated) // Configure the view for the selected state } }

ViewControllerコード

Swift

import UIKit class AnswerQuizViewController: UIViewController, UITableViewDelegate { var q: QuestionSeries! @IBOutlet weak var quizTableView: UITableView! override func viewDidLoad() { super.viewDidLoad() quizTableView.dataSource = self quizTableView.delegate = self // cell xibファイルを使うときは書く必要があるやつ。 // quizTableView.register(UINib(nibName: K.Cells.QuizCellNibName, bundle: nil), forCellReuseIdentifier: K.Cells.QuizCellIdentifier) quizTableView.register(UINib(nibName: "QuizCell", bundle: nil), forCellReuseIdentifier: "QuizCellIdentifier") // Do any additional setup after loading the view. } // MARK: - Navigation // In a storyboard-based application, you will often want to do a little preparation before navigation // override func prepare(for segue: UIStoryboardSegue, sender: Any?) { // // Get the new view controller using segue.destination. // // Pass the selected object to the new view controller. //// if segue.identifier == K.Segue.checkResult { //// let resultViewController = segue.destination as! ResultViewController //// answerQuizViewController.q = //// print(answerQuizViewController.q) // } } // MARK: - quizTableViewのアレンジ extension AnswerQuizViewController: UITableViewDataSource, QuizCellDelegate { func quizCellDidChangeCurrentButtonIndex(_ cell: QuizCell, index: Int) { if let indexPath = self.quizTableView.indexPath(for: cell){ self.q.question[indexPath.row].answer = index print(index) }else{ print("ここきてます") } } func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return q.question.count //print(q.question.count) } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let question = q.question[indexPath.row] let cell = quizTableView.dequeueReusableCell(withIdentifier: K.Cells.QuizCellIdentifier, for: indexPath) as! QuizCell cell.questionLabel.text = question.text // print(question.text) return cell } }

また、もし他の方法で実装できるなどご助言あれば、ぜひご教授いただけますと幸いです。
よろしくお願いいたします。

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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