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

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

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

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

Q&A

解決済

1回答

2080閲覧

pickerViewの外に値を移す

midori0822

総合スコア61

Swift

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

0グッド

0クリップ

投稿2017/10/30 16:08

タイトルの通りの質問です。
下記のコードで数値2つを入力、それを演算子1つ選んで計算するツールを作っています。

swift

1import UIKit 2 3class ViewController: UIViewController, UIPickerViewDelegate,UIPickerViewDataSource,UITextFieldDelegate { 4 5 override func viewDidLoad() { 6 super.viewDidLoad() 7 // Do any additional setup after loading the view, typically from a nib. 8 let suuzi1 = UITextField() 9 let suuzi2 = UITextField() 10 11 12 13 14 suuzi1.delegate = self 15 suuzi2.delegate = self 16 17 suuzi1.placeholder = "数字を入力" 18 suuzi2.placeholder = "数字を入力" 19 20 suuzi1.leftViewMode = .always 21 suuzi1.leftView = UIView(frame: CGRect(x:0,y:0,width:10,height:10)) 22 suuzi2.leftViewMode = .always 23 suuzi2.leftView = UIView(frame: CGRect(x:0,y:0,width:10,height:10)) 24 25 suuzi1.clearButtonMode = .always 26 suuzi2.clearButtonMode = .always 27 28 suuzi1.returnKeyType = .done 29 suuzi2.returnKeyType = .done 30 31 32 self.suuzi1.keyboardType = .numberPad 33 self.suuzi2.keyboardType = .numberPad 34 } 35 36 func textFieldShouldReturn(_ textField: UITextField) -> Bool { 37 suuzi1.resignFirstResponder() 38 suuzi2.resignFirstResponder() 39 return true 40 } 41 42 func textFieldShouldClear(_ textField: UITextField) -> Bool { 43 print("clear") 44 return true 45 } 46 func textFieldShouldBeginEditing(_ textField: UITextField) -> Bool { 47 print("start") 48 return true 49 } 50 51 func textFieldShouldEndEditing(_ textField: UITextField) -> Bool { 52 print("end") 53 return true 54 } 55 let enzansiX = ["+","-","×","÷"] 56 57 @IBOutlet weak var suuzi1: UITextField! 58 @IBOutlet weak var suuzi2: UITextField! 59 @IBOutlet weak var enzansi: UILabel! 60 @IBOutlet weak var result: UILabel! 61 62 63 64 func numberOfComponents(in pickerView: UIPickerView) -> Int { 65 return 1 66 } 67 68 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { 69 return enzansiX.count 70 71 } 72 func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { 73 return enzansiX[row] 74 } 75 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 76 let enzansiY:String = enzansiX[row] 77 78 enzansi.text = "enzansiX[row]" 79 80 switch enzansiY { 81 case "+": var resultX = Double(suuzi1.text!)! + Double(suuzi2.text!)! 82 case "-": var resultX = Double(suuzi1.text!)! - Double(suuzi2.text!)! 83 case "×": var resultX = Double(suuzi1.text!)! * Double(suuzi2.text!)! 84 case "÷": var resultX = Double(suuzi1.text!)! / Double(suuzi2.text!)! 85 default : break 86 87 } 88 89 } 90 @IBAction func calc(_ sender: Any) { 91 92 result.text = Double(suuzi1.text!)! + enzansiX[row] + Double(suuzi2.text!)! + "の答えは(resultX)です" 93 94 } 95

最後のcalcボタンを押したときに結果を表示したいのですが、

swift

1 result.text = Double(suuzi1.text!)! + enzansiX[row] + Double(suuzi2.text!)! + "の答えは(resultX)です"

このenzansiX[row],resultXの変数にそれぞれUse of unresolved identifier''の警告が出ます。
上記のpickerViewメソッド内で行われた代入値などはそのメソッド外では使えないのですか?
持ち出せるのであればその方法を教えてください。
suuzi1,suuzi2に警告が出てこないということはDelegateが関与しているのでしょうか。返信お待ちしております。

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

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

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

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

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

guest

回答1

0

ベストアンサー

###スコープの問題

swift

1 @IBAction func calc(_ sender: Any) { 2 3 result.text = Double(suuzi1.text!)! + enzansiX[row] + Double(suuzi2.text!)! + "の答えは(resultX)です" 4 5 }

このcalc関数内のresultXですがどこで宣言が行われているかと言うと

swift

1func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 2 let enzansiY:String = enzansiX[row] 3 4 enzansi.text = enzansiX[row] 5 6 switch enzansiY { 7 case "+": var resultX = Double(suuzi1.text!)! + Double(suuzi2.text!)! 8 case "-": var resultX = Double(suuzi1.text!)! - Double(suuzi2.text!)! 9 case "×": var resultX = Double(suuzi1.text!)! * Double(suuzi2.text!)! 10 case "÷": var resultX = Double(suuzi1.text!)! / Double(suuzi2.text!)! 11 default : break 12 } 13}

このswitch文の中です。これではcalc関数内からは見えません。なのでresultXをどこかcalc関数から見えるところに(例えばクラスの名前の1行下とか)に置いて、switch文のvarを全部取ってあげるとcalc関数はresultXが見えるようになります。またこの関数外にdidSelectedRow等の変数を用意しておき、この関数内で

swift

1didSelectedRow = row

としてあげればrowが外部でも使えるのであとは配列と組み合わせて使えばいいかと。
ですがこの辺りのやり方、ピッカーの操作が早すぎる場合にはきっちりついて来てくれない場合があるので注意です。

###型の問題

同一の型同士であれば+演算子が使えます。StringとString、IntとIntみたいな型同士ですね。ですがDoubleとStringのように型が違うと+演算子が使えません。また色んな値をまとめてStringにしようとするときは

swift

1result.text = "(Double(suuzi1.text!)!) (enzansiX[row]) (Double(suuzi2.text!)!) の答えは(resultX)です"

と最初から最後まで""で囲って上げるのが定石です(ダブルクォートといいます)。
また逆に

swift

1enzansi.text = "enzansiX[row]"

はダブルクォートを取ってあげないと+とかーではなくenzansiX[row]と言う文字列として扱われてしまいます。

###サンプル

swift

1 2import UIKit 3class ViewController: UIViewController, UIPickerViewDelegate,UIPickerViewDataSource,UITextFieldDelegate { 4 5 var resultX = Double(0) 6 let enzansiX = ["+","-","×","÷"] 7 8 var selectedRow = 0 9 10 @IBOutlet weak var suuzi1: UITextField! 11 @IBOutlet weak var suuzi2: UITextField! 12 @IBOutlet weak var enzansi: UILabel! 13 @IBOutlet weak var result: UILabel! 14 15 @IBAction func tap(_ sender: Any) { 16 result.text = "(Double(suuzi1.text!)!) (enzansiX[selectedRow]) (Double(suuzi2.text!)!) の答えは(resultX)です" 17 } 18 19 override func viewDidLoad() { 20 super.viewDidLoad() 21 // Do any additional setup after loading the view, typically from a nib. 22 let suuzi1 = UITextField() 23 let suuzi2 = UITextField() 24 25 suuzi1.delegate = self 26 suuzi2.delegate = self 27 28 suuzi1.placeholder = "数字を入力" 29 suuzi2.placeholder = "数字を入力" 30 31 suuzi1.leftViewMode = .always 32 suuzi1.leftView = UIView(frame: CGRect(x:0,y:0,width:10,height:10)) 33 suuzi2.leftViewMode = .always 34 suuzi2.leftView = UIView(frame: CGRect(x:0,y:0,width:10,height:10)) 35 36 suuzi1.clearButtonMode = .always 37 suuzi2.clearButtonMode = .always 38 39 suuzi1.returnKeyType = .done 40 suuzi2.returnKeyType = .done 41 42 self.suuzi1.keyboardType = .numberPad 43 self.suuzi2.keyboardType = .numberPad 44 } 45 46 func textFieldShouldReturn(_ textField: UITextField) -> Bool { 47 suuzi1.resignFirstResponder() 48 suuzi2.resignFirstResponder() 49 return true 50 } 51 52 func textFieldShouldClear(_ textField: UITextField) -> Bool { 53 print("clear") 54 return true 55 } 56 func textFieldShouldBeginEditing(_ textField: UITextField) -> Bool { 57 print("start") 58 return true 59 } 60 61 func textFieldShouldEndEditing(_ textField: UITextField) -> Bool { 62 print("end") 63 return true 64 } 65 66 func numberOfComponents(in pickerView: UIPickerView) -> Int { 67 return 1 68 } 69 70 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { 71 return enzansiX.count 72 73 } 74 func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { 75 return enzansiX[row] 76 } 77 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 78 let enzansiY:String = enzansiX[row] 79 80 enzansi.text = enzansiX[row] 81 82 switch enzansiY { 83 case "+": resultX = Double(suuzi1.text!)! + Double(suuzi2.text!)! 84 case "-": resultX = Double(suuzi1.text!)! - Double(suuzi2.text!)! 85 case "×": resultX = Double(suuzi1.text!)! * Double(suuzi2.text!)! 86 case "÷": resultX = Double(suuzi1.text!)! / Double(suuzi2.text!)! 87 default : break 88 } 89 selectedRow = row 90 91 } 92 93}

投稿2017/10/30 22:04

xAxis

総合スコア1349

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問