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

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

ただいまの
回答率

90.52%

  • Swift

    7227questions

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

【swift】pickerのtapイベントの実装について

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 591

SATOU_UKI

score 17

前提・実現したいこと
Picker(Cellに配置)を押した際のCell番号の取得

発生している問題
Pickerにtapイベントを実装し、Cell番号の取得するようにしたが、
tapイベントが発生しない

swiftでセル(コードとxlibで作成)にPickerを配置したのですが、Pickerを押した際にその
セルのIndexPathを取得したいのですが、以下のコードで取得することが出来ませんでした。

何が間違っているのかわからない為、もし、どなたかお分かりでしたら、教えていただけると嬉しいです。

下記コードは、
Pickerを押した時、そのpickerがあるセルの番号を取得する為、pickerに
UITapGestureRecognizerを加えて、tap時にPickerのtag(IndexPathの番号)を取得するように
プログラムを組んだつもりです。シュミレータでPickerを押しても、反応が無く、困っています。

//自作セル
import UIKit

class List_Act: UITableViewCell{

    @IBOutlet var ActImage: UIImageView!
    @IBOutlet var ActTitle: UILabel!
    @IBOutlet var ActPicker: UIPickerView!

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

    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)
    }   
}
class ActListVC: UIViewController, UITableViewDelegate, UITableViewDataSource ,UIPickerViewDelegate,UIPickerViewDataSource{

    private var MyUIPicker:UIPickerView!

    var PickerViewCount:[Int] = []
    var PickerViewCountList:[[String]] = [["a"."b"]["c".["d"]]
    var PickerTagNumber:Int = 0
    var myTableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()

        MyUIPicker = MyUIPickerView()
        MyUIPicker.isUserInteractionEnabled = true
        MyUIPicker.frame = CGRect(x: 0, y: 0, width: 100, height: 100)

        let displayWidth: CGFloat = self.view.frame.width
        let displayHeight: CGFloat = self.view.frame.height

        myTableView = UITableView(frame: CGRect(x: 0, y: 0, width: displayWidth, height: displayHeight)


        // Cellの登録. 
        let xib = UINib(nibName: "List_Act", bundle: nil)
        myTableView.register(xib,forCellReuseIdentifier:"Cell_Act")

        // DataSourceの設定.
        myTableView.dataSource = self

        // Delegateを設定.
        myTableView.delegate = self

        // TableViewをViewに追加する.
        self.view.addSubview(myTableView)
    }

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

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 2  
    }

    //Cellに値を設定する
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let tap = UITapGestureRecognizer(target: self, action: #selector(PickerTap(sender:)))
        let cell = tableView.dequeueReusableCell(withIdentifier: "Cell_Act") as! List_Act

        cell.ActPicker.delegate = self
        cell.ActPicker.dataSource = self
        cell.ActPicker.tag = indexPath.row
       //Pickerにタップジェスチャーを登録
        cell.ActPicker.addGestureRecognizer(tap)

        cell.ActPicker = MyUIPicker
        cell.ActPicker.isUserInteractionEnabled = true

        return cell
            }


    //これがシュミレータでPickerを押しても呼ばれない
    func PickerTap(sender:UITapGestureRecognizer){
        let SenderPick = sender.view as! UIPickerView
        PickerTagNumber = SenderPick.tag
        print("PickerTagNumber",PickerTagNumber) 

    }

   // pickerに表示する列数を返すデータソースメソッド.
    func numberOfComponents(in pickerView: UIPickerView) -> Int {
         return 1
    }    

   // pickerに表示する行数を返すデータソースメソッド
    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent
        component: Int) -> Int {
        return 2
    }

    //pickerに値を返すデリゲートメソッド.
    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int,
                    forComponent component: Int) -> String? {
        return PickerViewCountList[PickerTagNumber][row]
    }
     //pickerが選択された際に呼ばれるデリゲートメソッド.
    func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int,
                    inComponent component: Int) {} 




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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

check解決した方法

0

すみません。質問の内容が悪かったみたいです。

tableviewcellを作成時に
cell.ActPicker.tag = indexPath.row
とPickerに番号をつけておけば
Pickerを押した際のそのCell番号の取得することができました。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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

  • Swift

    7227questions

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