использовать 2 разных UIPanGestureRecongizer на 2 разных изображениях в viewController - PullRequest
0 голосов
/ 11 ноября 2019

мой код ниже инициализирует 2 разных изображения pg и tim. Я создал отдельную переменную для UIPanGestureRecognizer, которая будет использоваться для каждого изображения и функции для перемещения изображения с помощью UIPanGestureRecongizer. Прямо сейчас я не могу перемещать изображения вокруг. Когда я нажимаю на pg, он исчезает. Я просто хочу разработать функцию, которая позволит мне свободно перемещать каждое изображение. Весь мой код программный, поэтому вы можете просто скопировать код.

import UIKit

class ViewController: UIViewController {

var pg = UIImageView()
var pgGesture = UIPanGestureRecognizer()
var pgCon = [NSLayoutConstraint]()

var tim = UIImageView()
var timGesture = UIPanGestureRecognizer()
var timCon = [NSLayoutConstraint]()



override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view.



    [pg,tim].forEach({
        $0.translatesAutoresizingMaskIntoConstraints = false
        self.view.addSubview($0)
        $0.backgroundColor = UIColor.systemPink
        $0.isUserInteractionEnabled = true
    })


    pgGesture = UIPanGestureRecognizer(target: self, action: #selector(ViewController.pgGestureMethod(_:)))
    pg.addGestureRecognizer(pgGesture)


    timGesture = UIPanGestureRecognizer(target: self, action: #selector(ViewController.timGestureMethod(_:)))
    tim.addGestureRecognizer(timGesture)









    pgCon = [

        pg.trailingAnchor.constraint(equalTo: view.centerXAnchor, constant :37.5),
        pg.topAnchor.constraint(equalTo: view.centerYAnchor, constant : 225),
        pg.widthAnchor.constraint(equalToConstant: 75),
        pg.heightAnchor.constraint(equalToConstant: 50),
    ]


    NSLayoutConstraint.activate(pgCon)

    timCon = [

        tim.trailingAnchor.constraint(equalTo: view.centerXAnchor, constant :120),
        tim.topAnchor.constraint(equalTo: view.centerYAnchor, constant : 225),
        tim.widthAnchor.constraint(equalToConstant: 75),
        tim.heightAnchor.constraint(equalToConstant: 50),
    ]


    NSLayoutConstraint.activate(timCon)






}

@objc func pgGestureMethod(_ sender: UIPanGestureRecognizer){
    NSLayoutConstraint.deactivate(pgCon)
    NSLayoutConstraint.deactivate(timCon)
    self.view.bringSubviewToFront(pg)
    let tranistioon = sender.translation(in: self.view)
    pg.center = CGPoint(x: pg.center.x + tranistioon.x, y: pg.center.y + tranistioon.y)
    sender.setTranslation(CGPoint.zero,in: self.view)


}
@objc func timGestureMethod(_ sender: UIPanGestureRecognizer){
    NSLayoutConstraint.deactivate(timCon)
    NSLayoutConstraint.deactivate(pgCon)
    self.view.bringSubviewToFront(tim)
    let tranistioon = sender.translation(in: self.view)
    tim.center = CGPoint(x: tim.center.x + tranistioon.x, y: tim.center.y + tranistioon.y)
    sender.setTranslation(CGPoint.zero,in: self.view)


}
}

1 Ответ

0 голосов
/ 11 ноября 2019

Вместо constraints попробуйте присвоить frame обоим imageViews, т.е.

override func viewDidLoad() {
    super.viewDidLoad()

    pg.frame = CGRect(x: 100, y: 100, width: 75, height: 50) //here....
    tim.frame = CGRect(x: 200, y: 200, width: 75, height: 50) //here....

    //rest of the code...
}

. В приведенном выше коде

  1. изменить frameсогласно вашему требованию.
  2. из viewDidLoad() удалить код для применения constraints.
...