いつもお世話になっております。
UIPickerViewのtagについて質問させてください。
他の関数の関係で、 UIViewでタッチイベントを取得できるように拡張したところ、
pickerViewまでタッチイベントを取得するようになってしまいました。
そこでpickerにtagをマイナス値に設定して、touchEventgaが動作しないように条件わけしようとしたのですが、
設定したはずのtouchEventでtagをがなぜか0として取得してしまい、うまく動作しなくて困っております。
(また、Picker関係の関数では、tagを取得した場合、設定したtag通り、マイナスになっていました。)
実現したいことは、pickerViewを使う際に、touchEventgaが動作しないようにすることです。
どのようにすれば、解決できるでしょうか?
swift
1 2extension UIView { 3 override open func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 4 self.next?.touchesBegan(touches, with: event) 5 } 6 override open func touchesMoved(_ touches: Set<UITouch>, with event: UIEvent?) { 7 self.next?.touchesMoved(touches, with: event) 8 } 9 10 override open func touchesEnded(_ touches: Set<UITouch>, with event: UIEvent?) { 11 self.next?.touchesEnded(touches, with: event) 12 } 13 14class PickeVC: UIViewController,UIPickerViewDelegate,UIPickerViewDataSource{ 15} 16 17 18override func viewDidLoad() { 19 super.viewDidLoad() 20 var MyItem = [1,2,3,4,5] 21 22 var MyIPickerView1 = UIPickerView() 23 MyIPickerView1.delegate = self 24 MyIPickerView1.dataSource = self 25 MyPickerView1.frame = CGRect(x: 0 , y: 0 , width: 100, height: 50 ) 26 MyPickerView1.tag = -2 27 self.view.addSubview(MyPickerView1) 28 } 29 30 override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 31 let TouchEvent = touches.first! 32 if(TouchEvent.view!.tag >= 0){ 33 print("TouchEvent.view!.tag",TouchEvent.view!.tag) 34 } 35//ここでPickerのタグをマイナスに設定してあるはずなのにtagが0となってしまい、反応してしまう。 36 } 37 38 39 // pickerに表示する行数を返すデータソースメソッド 40 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent 41 component: Int) -> Int { 42 if (pickerView.tag == -2 ){ return MyItem.count } 43 else { return 3} 44 45 } 46 47//他、Picker関係の関数も問題なく動作したので、割愛 48 49} 50 51 52 53
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。