前提・実現したいこと
Picker(Cellに配置)を押した際のCell番号の取得
発生している問題
Pickerにtapイベントを実装し、Cell番号の取得するようにしたが、
tapイベントが発生しない
swiftでセル(コードとxlibで作成)にPickerを配置したのですが、Pickerを押した際にその
セルのIndexPathを取得したいのですが、以下のコードで取得することが出来ませんでした。
何が間違っているのかわからない為、もし、どなたかお分かりでしたら、教えていただけると嬉しいです。
下記コードは、
Pickerを押した時、そのpickerがあるセルの番号を取得する為、pickerに
UITapGestureRecognizerを加えて、tap時にPickerのtag(IndexPathの番号)を取得するように
プログラムを組んだつもりです。シュミレータでPickerを押しても、反応が無く、困っています。
Swift
1//自作セル 2import UIKit 3 4class List_Act: UITableViewCell{ 5 6 @IBOutlet var ActImage: UIImageView! 7 @IBOutlet var ActTitle: UILabel! 8 @IBOutlet var ActPicker: UIPickerView! 9 10 override func awakeFromNib() { 11 super.awakeFromNib() 12 } 13 14 override func setSelected(_ selected: Bool, animated: Bool) { 15 super.setSelected(selected, animated: animated) 16 } 17}
swift
1 2class ActListVC: UIViewController, UITableViewDelegate, UITableViewDataSource ,UIPickerViewDelegate,UIPickerViewDataSource{ 3 4 private var MyUIPicker:UIPickerView! 5 6 var PickerViewCount:[Int] = [] 7 var PickerViewCountList:[[String]] = [["a"."b"]["c".["d"]] 8 var PickerTagNumber:Int = 0 9 var myTableView: UITableView! 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 14 MyUIPicker = MyUIPickerView() 15 MyUIPicker.isUserInteractionEnabled = true 16 MyUIPicker.frame = CGRect(x: 0, y: 0, width: 100, height: 100) 17 18 let displayWidth: CGFloat = self.view.frame.width 19 let displayHeight: CGFloat = self.view.frame.height 20 21 myTableView = UITableView(frame: CGRect(x: 0, y: 0, width: displayWidth, height: displayHeight) 22 23 24 // Cellの登録. 25 let xib = UINib(nibName: "List_Act", bundle: nil) 26 myTableView.register(xib,forCellReuseIdentifier:"Cell_Act") 27 28 // DataSourceの設定. 29 myTableView.dataSource = self 30 31 // Delegateを設定. 32 myTableView.delegate = self 33 34 // TableViewをViewに追加する. 35 self.view.addSubview(myTableView) 36 } 37 38 override func didReceiveMemoryWarning() { 39 super.didReceiveMemoryWarning() 40 } 41 42 func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { } 43 44 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 45 return 2 46 } 47 48 //Cellに値を設定する 49 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 50 let tap = UITapGestureRecognizer(target: self, action: #selector(PickerTap(sender:))) 51 let cell = tableView.dequeueReusableCell(withIdentifier: "Cell_Act") as! List_Act 52 53 cell.ActPicker.delegate = self 54 cell.ActPicker.dataSource = self 55 cell.ActPicker.tag = indexPath.row 56 //Pickerにタップジェスチャーを登録 57 cell.ActPicker.addGestureRecognizer(tap) 58 59 cell.ActPicker = MyUIPicker 60 cell.ActPicker.isUserInteractionEnabled = true 61 62 return cell 63 } 64 65 66 //これがシュミレータでPickerを押しても呼ばれない 67 func PickerTap(sender:UITapGestureRecognizer){ 68 let SenderPick = sender.view as! UIPickerView 69 PickerTagNumber = SenderPick.tag 70 print("PickerTagNumber",PickerTagNumber) 71 72 } 73 74 // pickerに表示する列数を返すデータソースメソッド. 75 func numberOfComponents(in pickerView: UIPickerView) -> Int { 76 return 1 77 } 78 79 // pickerに表示する行数を返すデータソースメソッド 80 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent 81 component: Int) -> Int { 82 return 2 83 } 84 85 //pickerに値を返すデリゲートメソッド. 86 func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, 87 forComponent component: Int) -> String? { 88 return PickerViewCountList[PickerTagNumber][row] 89 } 90 //pickerが選択された際に呼ばれるデリゲートメソッド. 91 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, 92 inComponent component: Int) {} 93 94 95 96 97} 98
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。