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

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

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

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

Q&A

解決済

1回答

761閲覧

Swift shouldReceiveメソッドでジェスチャーを無効化したビューでUISliderが正常に動かないのですが

mitci

総合スコア37

Swift

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

0グッド

0クリップ

投稿2017/11/21 12:40

編集2017/11/22 14:03

###前提
1)storyboard上でこういう配置をしました。
こんな感じです
2)親ビューにタップジェスチャーをaddし、UIGestureRecognizerDelegateのshouldRecieveメソッドを利用して、子ビューにタップしても反応をしないようにしました。
3)すると、子ビュー上のUISliderのツマミをわずかに(具体的には100pxほど)動かしても、タップされた->shouldRecieveによって無効化 という処理が起こってしまい、本来のUISliderに紐つけていたIBActionメソッドが呼び出されなくなってしまいました。

###実現したいこと
そこで、子ビュー上でのタップジェスチャーを無効化していても、ちゃんとUISliderがわずかなツマミの位置変更も検出してくれるようにしたいです。

###該当のソースコード
以下のコードで子ビューをタップされた場合、親ビューにaddしたジェスチャーの#selectorメソッドが呼び出されないようにしています。

swift

1func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool { 2 3 guard let targetView = touch.view else { 4 fatalError() 5 } 6 7 if targetView == parentView.contentView { 8 return true 9 } else { 10 return false 11 } 12 } 13 14 @objc func dismissChildrenView() { 15 print("dismissChildren") 16 } 17 18}

###補足情報(言語/FW/ツール等のバージョンなど)
UISliderのツマミをタップと判断されないように大きくスライドさせたあとに指を離せば、ちゃんとtouchUpInsideのメソッドが呼ばれます。
ちなみに、ツマミに触れた時に呼ばれるtouchDownメソッドの方は、どんな状況でもちゃんと呼ばれています。

swift3 xcode8

###追記・前提2
子ビュー内においてあるUISliderは、MediaPlayerフレームワークを利用した音楽再生用のシークバーのため、min値を0に、max値を曲の再生時間にしてあります。
touchDownで[00:02]などの秒数表示ラベルを更新するタイマーを止めて、
valueChangedで現在のツマミの位置の秒数を[xx:xx]のフォーマットにして秒数ラベルに代入し、
touchUpで再び秒数表示の更新をするタイマーを再設定しています。

コードでいうと以下の通りです。

swift

1//UISliderのコード 2 func sliderTimerStart() { 3 sliderTimer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: #selector(sliderThumbPossitioning), userInfo: nil, repeats: true) 4 } 5 6 @IBAction func seekBarSlidertouchDown(_ sender: UISlider) { 7 sliderTimer.invalidate() 8 } 9 //タイマーを停止する 10 11 @IBAction func seekBarSliderValueChanged(_ sender: UISlider) { 12 let currentTimeValue = TimeInterval(sender.value) 13 let min = Int(currentTimeValue) / 60 14 let sec = Int(currentTimeValue) % 60 15 currentTime = String(format: "%02d:%02d", min, sec) 16 timeLabel.text = currentTime 17 } 18 //タイムラベルをツマミの位置へ更新 19 20 @IBAction func seekBarSliderTouchUpInside(_ sender: UISlider) { 21 player.currentPlaybackTime = TimeInterval(sender.value) 22 sliderTimerStart() 23 } 24 //再生時間をツマミの位置へ。タイマーの再開 25 26 @IBAction func seekBarSliderTouchUpOutside(_ sender: UISlider) { 27 player.currentPlaybackTime = TimeInterval(sender.value) 28 sliderTimerStart() 29 } 30

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

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

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

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

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

guest

回答1

0

ベストアンサー

Value Changed

Value Changedと紐付けすれば解決なんじゃないでしょうかね。

gif

投稿2017/11/21 13:12

xAxis

総合スコア1349

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

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

mitci

2017/11/22 13:44

Touch Down Value Changed は 確かに正常に作動しますが、 (そして前提に書き忘れていましたが・・・) TouchDownでタイマーを止めて、 ValueChangedでラベルの値を変更し、 TouchUpでタイマーを再設定しています。 そのタイマー再設定が呼ばれないので、わずかに触れるとタイマーが止まったままになってしまうんですよね・・・
mitci

2017/11/22 14:05

遅ればせながら、追記させていただきました。 こう書いているとなんだかUISlider関連が悪さをしているような気がしますね・・・ TouchDownが呼ばれているのに、ツマミをわずかにずらすと、「ツマミをタップされた」のではなく、その下にある「子ビューをタップされた」と判断されるのはおかしいですよね・・・?
xAxis

2017/11/25 10:33

体調を崩してしまいコメント遅くなってしまいました。すいません。 状況に関して了解しました。 UISliderのAction周りに関してなのですが、 ・touchDown ・touchDragInside ・touchUpInside ・touchUpOutside ・value Changed 以上のactionは正常に動いていました。 そしてSliderのつまみをわずかに動かしたところ並び順は value changed touch Down value changed touch Drag Inside value changed touch Drag Inside value changed touch Up Inside となりました。 手元のコード内のIBActionでつないだ関数の中にprint()を挟んでみてちゃんと各々の関数が呼ばれるか確かめられました?もし確かめられていて問題なく反応しているなら、自分なら次はsliderTimerStart()内にprint()を置いて状況を確認していますかね。
mitci

2017/11/27 12:23

こちらこそ遅くなりまして申し訳ございません。 かなり詳しく精査させていただいたところ、正直何がまちがっていたというところが不明のまま、 UISliderが正しく動作するようになっていました・・・ 予測ではありますが、 tapGestureの#selectorメソッド内で別のジェスチャーをaddしたり、それのdelegateを指定しなかったりの当たりが悪さをしていたような気がします・・・ かつ、gestureRecognizerDelegateの導入が正しく行われていなかったのかもしれません・・・ 本当にご迷惑をおかけして申し訳有りません。
xAxis

2017/11/29 10:18

いえいえ何はともあれ結果オーライですね。動いてよかったです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問