簡単なアラームアプリを作成しているのですが、その過程で分からないことがありますので、こちらで質問させていただきます。
##やりたいこと
参考サイト
-
上記のサイトを参考に、偏移先のView(Set View Controller)から戻ってきた時に、偏移元のView(Wakeup Time View Controller)にあるテーブルのデータを再表示させたい。
-
表示させる内容は、timeArrayというDate型の配列
-
Set View Controllerで日時を設定し、配列へ代入。Navigation Barの<Backで偏移元のWakeup Time View Controllerに戻ってきた時に、設定した日時を表示させたい。
##分からないこと
Swift
1//時間設定画面から戻ってきたときの処理 2override func viewWillAppear(_ animated: Bool) { 3 super.viewWillAppear(animated) 4 //tableViewを更新 5 tableView.reloadData() 6}
上記のようにテーブルをリロードする場合、リロードされるのはページだけでしょうか?
というのも、セルの個数を設定する以下の関数が更新されていないようです。
Swift
1 //セルの個数を設定 2 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 3 print("Num of row :(setViewController.timeArray.count)") 4 //配列の個数をリターン 5 return setViewController.timeArray.count 6 }
時間を設定して配列に代入して偏移元に戻った時に、セルの個数や中身も同時に更新して表示させたいのですが、そのように行うにはどのようにすれば良いのでしょうか?
長くなりましたが、アドバイスを頂けたら幸いです。
##WakeupTimeViewController.swift
import Foundation import UIKit class WakeupTimeViewController: UIViewController,UITableViewDelegate, UITableViewDataSource{ let setViewController = SetViewController() @IBOutlet var tableView: UITableView! //セルの個数を設定 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { print("Num of row :(setViewController.timeArray.count)") //配列の個数をリターン return setViewController.timeArray.count } //Table View CellのIdentifierを指定 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { // セルを取得する let cell: UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "TimeCell", for: indexPath) //Date -> Stringへ変換し、dateへ代入 let date = stringFromDate(date: setViewController.timeArray[indexPath.row], format: "yyyy年MM月dd日 HH時mm分ss秒") // セルに表示する値を設定する cell.textLabel!.text = date return cell } @IBOutlet var WakeupTimeArray: UITableView! //+が押されたときの処理 @IBAction func addTimeBtnWasPressed(_ sender: Any) { //時間設定画面へ performSegue(withIdentifier: "goTimeSetting", sender: nil) } override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. tableView.dataSource = self tableView.delegate = self tableView.tableFooterView = UIView(frame: .zero) } //時間設定画面から戻ってきたときの処理 override func viewWillAppear(_ animated: Bool) { super.viewWillAppear(animated) //tableViewを更新 tableView.reloadData() } //Date -> String変換 func stringFromDate(date: Date, format: String) -> String { let formatter: DateFormatter = DateFormatter() formatter.calendar = Calendar(identifier: .gregorian) formatter.dateFormat = format return formatter.string(from: date) } }
##SetViewController.swift
import UIKit import AVFoundation class SetViewController: UIViewController{ let alarm = Alarm() //A control for the inputting of date and time values var timeArray: [Date] = [] @IBOutlet var sleepTimePicker: UIDatePicker! override func viewDidLoad(){ super.viewDidLoad() //datePickerMode -> 日付ピッカーのモード設定 //dateAndTime -> The mode determines whether dates, times, or both dates and times are displayed sleepTimePicker.datePickerMode = UIDatePicker.Mode.dateAndTime //sets the date to display in the date picker sleepTimePicker.setDate(Date(), animated: false) } override func viewDidAppear(_ animated: Bool){ //sleepTimerがnil出ない場合 if alarm.sleepTimer != nil{ //再生されているタイマーを止める。 alarm.stopTimer() } } //SETボタンが押されたときの処理 @IBAction func setBtnWasPressed(_ sender: Any) { //selectedWakeUpTimeにユーザーの入力した日付を代入 //alarm.selectedWakeUpTime = sleepTimePicker.date timeArray.append(sleepTimePicker.date) print(timeArray) //タイマー実行 //alarm.runTimer() //アラートを設定 p.275 } }
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/03/14 13:59