Ниже показано, как панорамировать элемент управления UILabel
на главном виде контроллера представления (UIViewController
) и как ограничить его перемещение в пределах видимых границ последнего.Обратите внимание, что строка состояния считается видимой.Поэтому верхняя граница определяется высотой строки состояния.
import UIKit
class ViewController: UIViewController {
// MARK: - Variables
// MARK: - IBOutlet
@IBOutlet weak var label: UILabel!
// MARK: - IBAction
// MARK: - Life cycle
override func viewDidLoad() {
super.viewDidLoad()
let panGesture = UIPanGestureRecognizer(target: self, action: #selector(handlePan(_:)))
label.isUserInteractionEnabled = true
label.addGestureRecognizer(panGesture)
}
@objc func handlePan(_ sender: UIPanGestureRecognizer) {
let translation = sender.translation(in: self.view)
let statusFrame = UIApplication.shared.statusBarFrame
if let senderView = sender.view {
if senderView.frame.origin.x < 0.0 {
senderView.frame.origin = CGPoint(x: 0.0, y: senderView.frame.origin.y)
}
if senderView.frame.origin.y < statusFrame.height {
senderView.frame.origin = CGPoint(x: senderView.frame.origin.x, y: statusFrame.height)
}
if senderView.frame.origin.x + senderView.frame.size.width > view.frame.width {
senderView.frame.origin = CGPoint(x: view.frame.width - senderView.frame.size.width, y: senderView.frame.origin.y)
}
if senderView.frame.origin.y + senderView.frame.size.height > view.frame.height {
senderView.frame.origin = CGPoint(x: senderView.frame.origin.x, y: view.frame.height - senderView.frame.size.height)
}
}
if let centerX = sender.view?.center.x, let centerY = sender.view?.center.y {
sender.view?.center = CGPoint.init(x: centerX + translation.x , y: centerY + translation.y)
sender.setTranslation(CGPoint.zero, in: self.view)
}
}
}