Параметр Pass с UITapGestureRecognizer

Есть ли способ передать параметры с помощью UITapGestureRecognizer? Я видел, как это отвечало за objective-c, но не удалось найти ответ для быстрого

test.userInteractionEnabled = true
let tapRecognizer = UITapGestureRecognizer(target: self, action: Selector("imageTapped4:"))
// Something like text.myParamater
test.addGestureRecognizer(tapRecognizer)

И затем получите myParameter под func imageTapped4() {}

Ответ 1

Один из подходов заключается в том, чтобы создать подкласс UITapGestureRecognizer и затем установить свойство. Я разместил пример ниже. Вы также можете проверить отправителя и проверить, равен ли он некоторому тегу, классу, строке и т.д.

class ViewController: UIViewController {

    @IBOutlet weak var label1: UILabel!
    @IBOutlet weak var image: UIImageView!

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        image.userInteractionEnabled = true;
        let tappy = MyTapGesture(target: self, action: #selector(self.tapped(_:)))
        image.addGestureRecognizer(tappy)
        tappy.title = "val"
    }

    func tapped(sender : MyTapGesture) {
        print(sender.title)
        label1.text = sender.title
    }
}

class MyTapGesture: UITapGestureRecognizer {
    var title = String()
}

Есть много примеров на SO, посмотрите, удачи.

Ответ 2

Для Swift 4

В Viewdidload

let label     =   UILabel(frame: CGRect(x: 0, y: h, width: Int(self.phoneNumberView.bounds.width), height: 30))
                label.textColor = primaryColor
                label.numberOfLines = 0
                label.font = title3Font
                label.lineBreakMode = .byWordWrapping
                label.attributedText = fullString

 let phoneCall = MyTapGesture(target: self, action: #selector(self.openCall))
        phoneCall.phoneNumber = "\(res)"
            label.isUserInteractionEnabled = true
            label.addGestureRecognizer(phoneCall)

Функция как

@objc func openCall(sender : MyTapGesture) {
        let number = sender.phoneNumber
        print(number)
}

Написать класс как

class MyTapGesture: UITapGestureRecognizer {
    var phoneNumber = String()
}

Выполните шаг должным образом и внесите изменения в соответствии с вашей переменной, кнопкой, ярлыком. Это работает правильно

Ответ 3

Сообщение, передаваемое в жесты касания, в основном похоже на местоположение жестящего элемента, обнаруженного в представлении.

Предположим, что мы добавили жест коснуться в представлении контроллера self.view.

    override func viewDidLoad() {
    super.viewDidLoad()
    let tapGesture = UITapGestureRecognizer(target: self, action: #selector(self.printGesPostion))
    self.view.addGestureRecognizer(tapGesture)
    // Do any additional setup after loading the view, typically from a nib.
}

Мы можем реализовать метод printGesPosition как

    func printGesPostion(ges:UITapGestureRecognizer) {
    print(ges.locationInView(self.view))

    let subView = self.view.hitTest(ges.locationInView(self.view), withEvent: nil)
    if subView?.isKindOfClass(UILabel) == true {

       print( (subView as! UILabel).text! )
    }
}

В этом случае метод обнаруживает положение жестов кран, если он происходит на UILabel, он будет печатать label.text

Не забудьте установить label.userInteraction = true, либо в ViewDidLoad, либо просто в раскадровке.

Ответ 4

Лучший способ - определить параметр при запуске func imageTapped64. Вы можете получить параметры с помощью представления (посмотрите на ответ @Developer Sheldon) или многими другими способами.