В Swift 5 и iOS 12 UIGestureRecognizerDelegate
есть метод, называемый gestureRecognizer(_:shouldReceive:)
. gestureRecognizer(_:shouldReceive:)
имеет следующее объявление:
Спросите делегата, должен ли распознаватель жестов получать объект, представляющий прикосновение.
optional func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool
Полный код ниже показывает возможную реализацию для gestureRecognizer(_:shouldReceive:)
. С помощью этого кода нажатие на подвид ViewController
представления (включая imageView
) не запускает printHello(_:)
метод.
import UIKit
class ViewController: UIViewController, UIGestureRecognizerDelegate {
override func viewDidLoad() {
super.viewDidLoad()
let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(printHello))
tapGestureRecognizer.delegate = self
view.addGestureRecognizer(tapGestureRecognizer)
let imageView = UIImageView(image: UIImage(named: "icon")!)
imageView.frame = CGRect(x: 50, y: 50, width: 100, height: 100)
view.addSubview(imageView)
imageView.isUserInteractionEnabled = true
}
func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool {
if let touchedView = touch.view, let gestureView = gestureRecognizer.view, touchedView.isDescendant(of: gestureView), touchedView !== gestureView {
return false
}
return true
}
@objc func printHello(_ sender: UITapGestureRecognizer) {
print("Hello")
}
}
Альтернативной реализацией gestureRecognizer(_:shouldReceive:)
может быть:
func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool {
return gestureRecognizer.view === touch.view
}
Однако обратите внимание, что этот альтернативный код не проверяет, touch.view
является ли подпредставление gestureRecognizer.view
.