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

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

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

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

Swift

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

Q&A

解決済

1回答

480閲覧

swift: デリゲートをして別クラスのラベル、関数にアクセスしたい

mogiruri

総合スコア37

Xcode

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

Swift

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

0グッド

0クリップ

投稿2018/10/21 10:23

編集2018/10/21 22:20

こんにちは。
現在アプリを作成していて、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に代入できません。

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

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

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

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

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

guest

回答1

0

ベストアンサー

settingBtn内でDelegateを代入してはいかがでしょうか。

Swift

1let settingVC = storyboard.instantiateViewController(withIdentifier: "settingVC") as settingVC 2settingVC.delegate = self //これを追加 3self.present(settingVC, animated: true, completion: nil) 4

投稿2018/10/21 12:59

編集2018/10/23 12:10
nakasho_dev

総合スコア2655

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

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

mogiruri

2018/10/21 13:06

コメントありがとうございます。 ViewCintrollwe classのsettingButtonメソッドで .delegateを用いるということは、このクラス内で var delegate = VCDelegate を定義するということでしょうか?
nakasho_dev

2018/10/21 13:33

「settingVC」で既に定義していますよね。提示したように実装して動きませんか?
mogiruri

2018/10/21 21:38

このように記載するとUIViewControllerはdelegateメンバを持っていませんとエラーが出てしまいます。
mogiruri

2018/10/21 22:22

settingVCのdidLoadで 上記のようにすることでアクセスできました。ですが値を渡した後の関数内でtimerLabel.textに値が代入できません(nilだと言われます) 何か心当たりありませんか?
nakasho_dev

2018/10/23 12:12

castしていなかったのでメンバを持っていませんとエラーが出たようです。回答にcastについて追記しました。
mogiruri

2018/10/23 12:28

編集していただきありがとうございます。.delegateはアクティブになりましたが、やはりラベルに代入するところでnilのエラーが出てしまいます。userDefaultやappDelegateを用いてみましたがなかなかうまくいかないのでどこか根本的なところが間違っているのだと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問