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

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

ただいまの
回答率

90.49%

  • Xcode

    4199questions

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

  • Swift 2

    1334questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

UITextFieldの選択状態を検知する方法

解決済

回答 1

投稿

  • 評価
  • クリップ 2
  • VIEW 2,199

pocky

score 24

UITextFieldを複数個storyboard上に配置させ、それぞれでピッカーを表示させようと考えています。

そこで、ピッカーを表示させる際に、このテキストフィールドをタップした時にはこのピッカーを表示させ、他のテキストフィールドをタップした時には他のピッカーを表示させる。というようにしたいのですが、どのようにしてそれぞれのテキストフィールドをタップしたことを検知すれば良いのかご教授お願いします。

現状以下のようなどちらを選択しても同じピッカーが現れるようになっています。
イメージ説明

以下、コードを乗せておきます。

class MyPageViewController: UIViewController,UIPickerViewDelegate,UIPickerViewDataSource,UIToolbarDelegate{

    var myToolBar:UIToolbar!

    let sexList = ["ーーーーー","男","女"]
    let addressList = ["ーーーーー","北海道","青森"]

    @IBOutlet weak var sexText: UITextField!
    @IBOutlet weak var addressText: UITextField!

    override func viewDidLoad() {
        super.viewDidLoad()

        let myPicker = UIPickerView()

        myPicker.delegate = self
        myPicker.dataSource = self

        sexText.inputView = myPicker
        addressText.inputView = myPicker

        myToolBar = UIToolbar(frame: CGRectMake(0, self.view.frame.size.height/6, self.view.frame.size.width, 40.0))
        myToolBar.layer.position = CGPoint(x: self.view.frame.size.width/2, y: self.view.frame.size.height-20.0)
        myToolBar.barStyle = .Default

        let toolBarBtn = UIBarButtonItem(title: "完了", style: .Plain, target: self, action: "myOK:")
        toolBarBtn.tag = 1
        myToolBar.items = [toolBarBtn]

        sexText.inputAccessoryView = myToolBar
        addressText.inputAccessoryView = myToolBar
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }

    func myOK(sender: UIBarButtonItem) {
        sexText.resignFirstResponder()
        addressText.resignFirstResponder()
    }

    func numberOfComponentsInPickerView(picker:UIPickerView)->Int{
        return 1
    }

    func pickerView(picker:UIPickerView,numberOfRowsInComponent component:Int)->Int{

        return sexList.count
    }

    func pickerView(picker:UIPickerView,titleForRow row:Int,forComponent component:Int)->String?{
        return sexList[row]
    }

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

簡単に分けるとすると、以下のようになると思います。

import UIKit

// ↓ 追加(UITextFieldDelegate ※Storyboardで設定しても可)
class MyPageViewController: UIViewController,UIPickerViewDelegate,UIPickerViewDataSource,UIToolbarDelegate, UITextFieldDelegate {

    var myToolBar:UIToolbar!

    let sexList = ["ーーーーー","男","女"]
    let addressList = ["ーーーーー","北海道","青森"]

    // ↓ 追加
    var dataList: [String] = []

    let myPicker = UIPickerView()

    @IBOutlet weak var sexText: UITextField!
    @IBOutlet weak var addressText: UITextField!

    override func viewDidLoad() {
        super.viewDidLoad()

        // ↓ 追加
        sexText.delegate = self
        addressText.delegate = self
        sexText.tag = 1
        addressText.tag = 2


        myPicker.delegate = self
        myPicker.dataSource = self

        sexText.inputView = myPicker
        addressText.inputView = myPicker

        myToolBar = UIToolbar(frame: CGRectMake(0, self.view.frame.size.height/6, self.view.frame.size.width, 40.0))
        myToolBar.layer.position = CGPoint(x: self.view.frame.size.width/2, y: self.view.frame.size.height-20.0)
        myToolBar.barStyle = .Default

        let toolBarBtn = UIBarButtonItem(title: "完了", style: .Plain, target: self, action: "myOK:")
        toolBarBtn.tag = 1
        myToolBar.items = [toolBarBtn]

        sexText.inputAccessoryView = myToolBar
        addressText.inputAccessoryView = myToolBar
    }

    // ↓ 追加
    func textFieldShouldBeginEditing(textField: UITextField) -> Bool {
        dataList = textField.tag == 1 ? sexList : addressList
        myPicker.reloadAllComponents()
        return true
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }

    func myOK(sender: UIBarButtonItem) {
        sexText.resignFirstResponder()
        addressText.resignFirstResponder()
    }

    func numberOfComponentsInPickerView(picker:UIPickerView)->Int{
        return 1
    }

    func pickerView(picker:UIPickerView,numberOfRowsInComponent component:Int)->Int{
        // ↓ 変更
        return dataList.count
    }

    func pickerView(picker:UIPickerView,titleForRow row:Int,forComponent component:Int)->String?{
        // ↓ 変更
        return dataList[row]
    }
}

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/05/09 23:24

    ご回答ありがとうございます。
    Kenterou様のいう通りコードを変更してみましたところ、少し挙動はおかしいですが、初めてタップした時点ではそれぞれのピッカーを表示することができました。
    ありがとうございます。

    もう一つお聞きしたいのですが、textFieldShouldBeginEditing関数で
    dataList = textField.tag == 1 ? sexList : addressList
    と表記されていますが、勉強不足のため全く理解出来ませんでした。
    何をしているのか少し教えて頂けませんか?

    キャンセル

  • 2016/05/09 23:37 編集

    dataListは表示する配列で、そこにsexListかaddressListのどちらかを入れるという処理です。
    ※三項演算子という書き方になります。

    テキストフィールドにフォーカスが入った時にDelegateメソッドが呼ばれ、この時の引数にフォーカスの入ったtextFieldが渡ってくるのでそのtextfieldのタグが1(true)だったら(sexText)なのでdataListにsexListをセットしているという事です。

    キャンセル

  • 2016/05/09 23:44

    ありがとうございました。
    勉強します。

    キャンセル

  • 2016/05/09 23:47

    完了を押さず、ピッカーを切り替えた時に配列ごと切り替える様に回答を変更しました。
    試してみてください。

    キャンセル

  • 2016/05/10 22:27

    ご丁寧にありがとうございます!
    このコードは保存しておきます。
    本当に感謝です。

    キャンセル

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

  • ただいまの回答率 90.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Xcode

    4199questions

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

  • Swift 2

    1334questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。