swift - 连接到平移手势的 y 轴上的中心对象

标签 swift alignment frame uipangesturerecognizer yaxis

我希望我的 swift 代码将连接到 uipangesture 的框架居中放置在 y 轴上。您可以在下面创建的 gif 中看到我在寻找什么。现在我已经找到了一种方法来做到这一点。我发现您可以使用 nslayout 约束并将它们设置为 true 来执行类似的操作。但它会将框移动到屏幕顶部,我想做一些类似于下面的 gif 的事情。

enter image description here

enter image description here

import UIKit

class ViewController: UIViewController {
    
    var container = UIView()
  
    
    var panGesture = UIPanGestureRecognizer()
    var btn = UIButton()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        
        [container,btn].forEach{
            $0.translatesAutoresizingMaskIntoConstraints = false
            view.addSubview($0)
        }
        container.isUserInteractionEnabled = true
        btn.frame = CGRect(x: 100, y: 300, width: 100, height: 100)
        container.frame = CGRect(x: 100, y: 100, width: 100, height: 100)
        container.backgroundColor = .blue
        btn.backgroundColor = .red
        panGesture = UIPanGestureRecognizer(target: self, action: #selector(ViewController.draggedView(_:)))
        container.isUserInteractionEnabled = true
        container.addGestureRecognizer(panGesture)
        
        btn.addTarget(self, action: #selector(centerYAlighment), for: .touchDown)

    }
    
    @objc func draggedView(_ sender: UIPanGestureRecognizer) {
        self.view.bringSubview(toFront: container)
        let translation = sender.translation(in: self.view)
        container.center = CGPoint(x: container.center.x + translation.x , y: container.center.y + translation.y)
        sender.setTranslation(CGPoint.zero, in: self.view)
        
        
        
        
        
    }
    
    @objc func centerYAlighment(){
       
    }


}

最佳答案

有关如何将蓝色方 block 的平移限制为仅沿中心 Y 轴的平移,请参阅此答案的历史记录


编辑:

如果你想让红色按钮水平居中蓝色方 block ,只需执行container.center.x = view.center.x里面centerYAlignment() .

class ViewController: UIViewController {
    
    var container = UIView()
      
    var panGesture = UIPanGestureRecognizer()
    var btn = UIButton()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        [container,btn].forEach{
            $0.translatesAutoresizingMaskIntoConstraints = false
            view.addSubview($0)
        }
        container.isUserInteractionEnabled = true
        btn.frame = CGRect(x: 100, y: 300, width: 100, height: 100)
        container.frame = CGRect(x: 100, y: 100, width: 100, height: 100)
        container.backgroundColor = .blue
        btn.backgroundColor = .red
        panGesture = UIPanGestureRecognizer(target: self, action: #selector(draggedView(_:)))
        container.isUserInteractionEnabled = true
        container.addGestureRecognizer(panGesture)
        
        btn.addTarget(self, action: #selector(centerYAlignment), for: .touchDown)

    }
    
    @objc func draggedView(_ sender: UIPanGestureRecognizer) {
        self.view.bringSubviewToFront(container)
        let translation = sender.translation(in: self.view)
        container.center = CGPoint(x: container.center.x + translation.x, y: container.center.y + translation.y)
        sender.setTranslation(CGPoint.zero, in: self.view)
    }
    
    
    @objc func centerYAlignment() {
        container.center.x = view.center.x /// here!
    }
}

结果:

Pressing red button centers blue square horizontally

关于swift - 连接到平移手势的 y 轴上的中心对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66987964/

相关文章:

javascript - Chart.js - 更改 x 轴时间序列的刻度/标签位置

ios - 如何使标签宽度自动调整

iphone - 如何设置 iPhone 5 的边框尺寸

框架导航中的 UWP 框架 - 如何访问父框架?

arrays - 如何过滤数组以确保它确实包含另一个数组的位置

swift - Swift 表达式中的两个等号

ios - 如何从 Swift 中的字符串生成条形码?

html - 如何在 3 行中动态居中对齐 3+ div?

ios - 如何设置变量以从 Swift 中的 Firebase 数据库结构中获取值

html - 对齐错误