让可拖动的 UIImage 移回原点位置

Let draggable UIImage move back to origin position

编辑: 我能够以某种方式更改代码,使程序不再崩溃。但是,代码只剩下一个小问题:

正如您在我的控制台输出中看到的那样,原点 2 的坐标与原点 1 中的坐标不同。

origin1: (268.0, 241.0) origin2: (116.0, 323.0) sender view center: Optional((146.5, 397.0))

所以我需要从 viewDidLoad() 获取 imageOrigin1 值并在 im func handlePan(sender:UIPanGestureRecognizer) 中使用它们。 我只是不知道该怎么做...

import UIKit

class ViewController: UIViewController {


    @IBOutlet weak var image: UIImageView!
    @IBOutlet weak var correctField: UIImageView!

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.

    }

    override func viewDidLoad() {
        super.viewDidLoad()

        let imageOrigin1 = image.frame.origin

        print("origin1: \(imageOrigin1)")
    }

    @IBAction func handlePan(sender:UIPanGestureRecognizer) {

        let imageOrigin2 = image.frame.origin

        let translation = sender.translationInView(self.view)

        if let view = sender.view {
            view.center = CGPoint(x:view.center.x + translation.x,
                                  y:view.center.y + translation.y)
        }

        if sender.state == UIGestureRecognizerState.Ended {

            if correctField.frame.contains(sender.view!.center){
                print("Correct")
                sender.setTranslation(CGPointZero, inView: self.view)
            } else{
                    print("origin2: \(imageOrigin2)")
                    print("sender view center: \(sender.view?.center)")
                //sender.view?.center = imageOrigin
            }
        }
    }
}

我自己解决了这个问题,添加了一个新的 class 并通过 set 和 get 方法传递变量:

CLASS:

import UIKit

class Origin {

var positionOrigin: CGPoint!

    func setImageOrigin(Image: UIImageView) {
        positionOrigin = Image.center
    }

    func getImageOrigin() -> CGPoint {
        return positionOrigin
    }
}

查看控制器:

import UIKit

class ViewController: UIViewController {

    @IBOutlet weak var correctField: UIImageView!
    @IBOutlet weak var image: UIImageView!

    var imageOrigin = Origin()

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.

    }

    override func viewDidLoad() {
        super.viewDidLoad()

        imageOrigin.setImageOrigin(image)

    }

    @IBAction func handlePan(sender:UIPanGestureRecognizer) {

        let translation = sender.translationInView(self.view)

        if let view = sender.view {
            view.center = CGPoint(x:view.center.x + translation.x,
                                  y:view.center.y + translation.y)
            sender.setTranslation(CGPointZero, inView: self.view)

        }

        if sender.state == UIGestureRecognizerState.Ended {

            if correctField.frame.contains(sender.view!.center){
                print("Correct")

            } else{

                image.center = imageOrigin.getImageOrigin()

            }
        }
    }
}