UIPanGestureRecognizer для программно добавленного UIView
Не могли бы вы мне помочь. Я хочу создать круг после долгого нажатия и заставить его двигаться жестом панорамирования, все еще нажимая пальцем на экран. Когда палец убирается с экрана, из него следует удалить круг. Создание круга с помощью длинного касания работает нормально, просто оно не двигается. Код ниже:
@IBAction func spaceLongPressed(_ guesture: UILongPressGestureRecognizer) {
let location = guesture.location(in: space)
var panGesture = UIPanGestureRecognizer()
circleView = UIView(frame: CGRect(x: location.x - space.bounds.height/4, y: location.y - space.bounds.height/4, width: space.bounds.height/2, height: space.bounds.height/2))
if guesture.state == .began {
circleView.backgroundColor = UIColor.red
circleView.isUserInteractionEnabled = true
circleView.tag = 100
circleView.layer.cornerRadius = circleView.bounds.height/2
space.addSubview(circleView)
panGesture = UIPanGestureRecognizer(target: space, action: #selector(didPan(sender:)))
space.addGestureRecognizer(panGesture)
}
if guesture.state == .ended {
if let viewWithTag = self.view.viewWithTag(100) {
viewWithTag.removeFromSuperview()
}
}
}
@objc func didPan(sender: UIPanGestureRecognizer) {
if sender.state == .began {
let translation = sender.translation(in: sender.view)
let changeX = (sender.view?.center.x)! + translation.x
let changeY = (sender.view?.center.y)! + translation.y
sender.view?.center = CGPoint(x: changeX, y: changeY)
sender.setTranslation(CGPoint.zero, in: sender.view)
}
}
Объект "space" относится к типу UIButton - я хочу создать круг в кнопке.
1 ответ
Решение
Не нужно создавать panGesture для обновления позиции. Вы можете получить тот же эффект с помощью долгого нажатия жеста. (Я немного изменил приведенный выше код, особенно вид рамки при создании).
var circleView: UIView!
@IBAction func spaceLongPressed(_ guesture: UILongPressGestureRecognizer) {
let location = guesture.location(in: view)
let size = CGSize(width: 100, height: 100)
circleView = UIView(frame: CGRect(origin: location, size: size))
if guesture.state == .began {
circleView.backgroundColor = UIColor.red
circleView.isUserInteractionEnabled = true
circleView.tag = 100
circleView.layer.cornerRadius = circleView.bounds.height/2
view.addSubview(circleView)
}
if guesture.state == .changed {
let position = guesture.location(in: view)
if let viewWithTag = self.view.viewWithTag(100) {
viewWithTag.center = position
}
}
if guesture.state == .ended {
if let viewWithTag = self.view.viewWithTag(100) {
viewWithTag.removeFromSuperview()
}
}
}