Параметр 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)
или многими другими способами.