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

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

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

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

Swift

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

Q&A

解決済

1回答

2468閲覧

UIPickerViewの DataSourceとDelegateを他のクラスから呼ぶ方法について

P-san

総合スコア21

Xcode

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

Swift

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

0グッド

0クリップ

投稿2017/01/31 06:29

編集2017/01/31 06:39

UIPickerについての質問です。
UIPickerのDataSourceとDelegateを設計上、
別のクラスから参照したいのですがどういうわけか、うまくいきません。

TableViewでは
参照したいクラスを定数で設定し、
delegateとdataSorceのselfをその定数名に設定すればできました。
しかし、PickerViewだとなぜかうまくいきませんでした。
何か間違えているのでしょうか。

###前提・実現したいこと

UIPickerのDataSourceとDelegateを別のクラスから呼びたいです。

###発生している問題・エラーメッセージ
ビルドは問題なかったのですが、シュミレーターでみた際、Pickerに値が反映されませんでした。

###該当のソースコード

Swift

1// ViewController 2 3import UIKit 4 5class ViewController: UIViewController { 6 // テキストフィールド 7 @IBOutlet weak var textFeild: UITextField! 8 // ピッカービュー 9 var myPicker: UIPickerView? 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 14 // DataSourceとDelegateのクラス 15 let dataSource = PickerData() 16 17 myPicker = UIPickerView() 18 myPicker?.frame = CGRect(x: 0, y: 0, width: UIScreen.main.bounds.size.width, height: (myPicker?.bounds.size.height)!) 19 20 // うまく参照できていない? 21 myPicker?.delegate = dataSource 22 myPicker?.dataSource = dataSource 23 24 textFeild.inputView = myPicker 25 } 26 27 override func didReceiveMemoryWarning() { 28 super.didReceiveMemoryWarning() 29 // Dispose of any resources that can be recreated. 30 } 31}

Swift

1// PickerData 2 3import UIKit 4 5class PickerData: NSObject , UIPickerViewDataSource , UIPickerViewDelegate { 6 7 // DataSource 8 func numberOfComponents(in pickerView: UIPickerView) -> Int { 9 return 1 10 } 11 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { 12 return 1 13 } 14 15 // Delegate 16 func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { 17 return "hogehoge" 18 19 } 20 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 21 } 22}

###試したこと
TableViewでは問題なくできました。

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

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

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

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

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

guest

回答1

0

ベストアンサー

let dataSource = PickerData()の宣言する場所の問題では無いでしょうか?viewDidLoad()メソッドの中で宣言した変数はそのスコープの中でしか有効ではありません、以下のようにインスタンス変数として宣言するとできると思います。

swift

1import UIKit 2 3class ViewController: UIViewController { 4 // テキストフィールド 5 @IBOutlet weak var textFeild: UITextField! 6 // ピッカービュー 7 var myPicker: UIPickerView? 8 9 let dataSource = PickerData() 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 14 // DataSourceとDelegateのクラス 15 16 myPicker = UIPickerView() 17 myPicker?.frame = CGRect(x: 0, y: 0, width: UIScreen.main.bounds.size.width, height: (myPicker?.bounds.size.height)!) 18 19 // うまく参照できていない? 20 myPicker?.delegate = dataSource 21 myPicker?.dataSource = dataSource 22 23 textFeild.inputView = myPicker 24 } 25}

投稿2017/01/31 13:04

_Kentarou

総合スコア8490

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

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

P-san

2017/02/01 01:46

うまくいきました。 勉強になります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問