こんにちは。
現在アプリを作成していて、BクラスからAクラスの fooLabel.text に、Aクラスの関数を用いて値を代入したいのですがどうもできずに困っています。
調べてみたデリゲートを実装してみたのですがどうやらメソッドにアクセスできていません。
助言をお願いいたします。
。
。
。
いじりたいUILabel func があるclass
swift
1 2import UIKit 3 4 5class ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate, VCDelegate { 6 7 8 @IBOutlet weak var layerView: UIView! 9 @IBOutlet weak var timerLabel: UILabel! 10 @IBOutlet weak var startBtn: CustomButton! 11 @IBOutlet weak var stopBtn: CustomButton! 12 @IBOutlet weak var finishBtn: CustomButton! 13 14 var totalTime = 0 15 16 var timer = Timer() 17 var isTimerRunning = false 18 var resumeTapped = false 19 20 21 @IBAction func startBtn(_ sender: Any) { 22 23 if isTimerRunning == false { 24 runTimer() 25 self.startBtn.isEnabled = false 26 stopBtn.isEnabled = true 27 } 28 29 } 30 31 @IBAction func stopBtn(_ sender: Any) { 32 33 if resumeTapped == false { 34 timer.invalidate() 35 self.resumeTapped = true 36 self.stopBtn.setTitle("Resume", for: .normal) 37 } 38 39 } 40 41 @IBAction func finishBtn(_ sender: Any) { 42 43 alertShow() 44 } 45 46 47 override func viewDidLoad() { 48 super.viewDidLoad() 49 50 layerView.backgroundColor = UIColor(red: 0, green: 0, blue: 0, alpha: 0.5) 51 52 print(timerLabel.text!) 53 } 54 55 56 57 @IBAction func settingBtn(_ sender: Any) { 58 59 let storyboard: UIStoryboard = self.storyboard! 60 let settingVC = storyboard.instantiateViewController(withIdentifier: "settingVC") 61 self.present(settingVC, animated: true, completion: nil) 62 63 } 64 65 66 67} 68 69 70 71extension ViewController { 72 73 74 75 func timeString(time: TimeInterval) -> String{ 76 let hour = Int(time) / 3600 77 let minute = Int(time) / 60 % 60 78 let second = Int(time) % 60 79 print("success") 80 return String(format:"%02i:%02i:%02i", hour, minute, second) 81 } 82 83 84 85 @objc func updateTimer() { 86 if totalTime < 1 { 87 timer.invalidate() 88 }else{ 89 totalTime -= 1 90 timerLabel.text = timeString(time: TimeInterval(totalTime)) 91 } 92 } 93 94 95 96 func runTimer() { 97 timer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: #selector(updateTimer), userInfo: nil, repeats: true) 98 isTimerRunning = true 99 stopBtn.isEnabled = true 100 } 101 102 103 104 func alertShow(){ 105 106 let alert: UIAlertController = UIAlertController(title: "Confirmation", message: "Have you finished?", preferredStyle: UIAlertController.Style.alert) 107 108 let saveAction: UIAlertAction = UIAlertAction(title: "Save Record", style: UIAlertAction.Style.default) { (UIAlertAction) in 109 110 // save process 111 112 } 113 114 let unsaveAction: UIAlertAction = UIAlertAction(title: "Unsave Record", style: UIAlertAction.Style.destructive) { (UIAlertAction) in 115 116 // unsave process 117 118 } 119 120 let cancelAction: UIAlertAction = UIAlertAction(title: "Cancel", style: UIAlertAction.Style.cancel) { (UIAlertAction) in 121 122 // cancel process 123 124 } 125 126 alert.addAction(saveAction) 127 alert.addAction(unsaveAction) 128 alert.addAction(cancelAction) 129 130 self.present(alert, animated: true, completion: nil) 131 132 } 133 134 135 func setTime(_ time: String){ 136 // time には値がある 137 print("success (time)") 138 // nilだと言われる。 didloadで行うとしっかり入っていた 139 print(timerLabel.text) 140 timerLabel.text = time // nilが入っていると言われます。 141 142 } 143} 144
.
.
.
アクセスしたい側のclass
swift
1 2import UIKit 3 4var records = ["test", "tst"] 5 6//プロトコル 7protocol VCDelegate{ 8 func timeString(time: TimeInterval) -> String 9 func setTime(_ time: String) 10} 11 12 13class settingVC: UIViewController, UITableViewDelegate, UITableViewDataSource { 14 15 var delegate: VCDelegate? 16 17 @IBOutlet weak var settingView: DesignableView! 18 @IBOutlet weak var tableView: UITableView! 19 @IBOutlet weak var hField: UITextField! 20 @IBOutlet weak var mField: UITextField! 21 @IBOutlet weak var sField: UITextField! 22 23 var hours = 0 24 var minutes = 0 25 var seconds = 0 26 var totalTime = 0 27 28 29 30 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 31 return records.count 32 } 33 34 35 36 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 37 let cell = UITableViewCell(style: UITableViewCell.CellStyle.default, reuseIdentifier: "cell") 38 cell.textLabel?.text = records[indexPath.row] 39 cell.backgroundColor = UIColor.clear 40 cell.textLabel?.textColor = UIColor.white 41 42 return cell 43 } 44 45 46 47 @IBAction func cancelBtn(_ sender: Any) { 48 self.dismiss(animated: true, completion: nil) 49 } 50 51 52 53 @IBAction func setBtn(_ sender: Any) { 54 55 if hField.text != "" && mField.text != "" && sField.text != "" { 56 57 hours = Int(hField.text!)! * 3600 58 minutes = Int(mField.text!)! * 60 59 seconds = Int(hField.text!)! 60 totalTime = hours + minutes + seconds 61 62 var delTime = delegate?.timeString(time: TimeInterval(totalTime)) 63 delegate?.setTime(delTime!) 64 65 66 self.dismiss(animated: true, completion: nil) 67 } 68 69 } 70 71 72 73 override func viewDidLoad() { 74 75 super.viewDidLoad() 76 tableView.backgroundColor = UIColor.clear 77 settingView.backgroundColor = UIColor(white: 0.7, alpha: 0.8) 78 79 let vc = ViewController() 80 self.delegate = vc 81 82 } 83 84} 85
追記
デリゲートはできました。が、ViewController下部のsetTime()ないで timerLabel.textに代入できません。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/10/21 13:06
2018/10/21 13:33
2018/10/21 21:38
2018/10/21 22:22
2018/10/23 12:12
2018/10/23 12:28