gpt4 book ai didi

ios - 如何在swift中更新 anchor 约束

转载 作者:行者123 更新时间:2023-11-28 10:34:58 25 4
gpt4 key购买 nike

我想在 iOS 中创建一个类似 android 的菜单。我正在使用布局约束 来设置约束。当我尝试在单击按钮时更新图像的左侧 约束 时遇到了问题(它应该根据单击按钮的位置设置动画)。谁能帮我?它应该支持横向和纵向。

我不想使用第三方代码,也不想使用 NSLayoutconstraint

Landscape image Potrait Image

这是我的代码。

class MenuViewController: UIViewController {
var buttons: [UIButton] = []
var imageView : UIImageView!

override func viewDidLoad() {
super.viewDidLoad()
}

override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
addMenuItems()
}

func addMenuItems() {

for _ in 0...4 {
let button : UIButton = UIButton()
self.view.addSubview(button)
button.backgroundColor = UIColor.darkGray
button.addTarget(self, action: #selector(didSelectedButton(_:)), for: .touchUpInside)
self.buttons.append(button)

}

for (index, button) in buttons.enumerated() {

button.setTitle(" \(index)", for: .normal)
if index == 0 {
button.translatesAutoresizingMaskIntoConstraints = false
button.leftAnchor.constraint(equalTo: self.view.safeAreaLayoutGuide.leftAnchor, constant: 0).isActive = true
button.widthAnchor.constraint(greaterThanOrEqualToConstant: 1).isActive = true
button.heightAnchor.constraint(equalToConstant: 50).isActive = true
button.topAnchor.constraint(equalTo: self.view.topAnchor, constant:200).isActive = true

self.imageView = UIImageView()
self.view.addSubview(self.imageView)
self.imageView.backgroundColor = UIColor.red

self.imageView.translatesAutoresizingMaskIntoConstraints = false
self.imageView.leftAnchor.constraint(equalTo: button.leftAnchor, constant: 0).isActive = true
self.imageView.widthAnchor.constraint(equalTo: button.widthAnchor, multiplier: 1).isActive = true
self.imageView.heightAnchor.constraint(equalToConstant: 4).isActive = true
self.imageView.topAnchor.constraint(equalTo: self.view.topAnchor, constant:250).isActive = true

}
else {

let preButton = buttons\[index - 1\]
button.translatesAutoresizingMaskIntoConstraints = false
button.leftAnchor.constraint(equalTo: preButton.rightAnchor, constant: 0).isActive = true
button.widthAnchor.constraint(equalTo: preButton.widthAnchor, multiplier: 1).isActive = true
button.heightAnchor.constraint(equalToConstant: 50).isActive = true
button.topAnchor.constraint(equalTo: self.view.topAnchor, constant:200).isActive = true
if index == self.buttons.count - 1 {
button.rightAnchor.constraint(equalTo: self.view.safeAreaLayoutGuide.rightAnchor, constant: 0).isActive = true
}
}

}

}

@objc func didSelectedButton(_ button:UIButton) {
UIView.animate(withDuration: 1, animations: {
self.imageView.leftAnchor.constraint(equalTo: button.leftAnchor).isActive = true
self.imageView.layoutIfNeeded()
}, completion: nil)
}

}

最佳答案

使用 anchor 创建 NSLayoutContraint。您需要在创建新的时停用以前的。

将此属性添加到您的 MenuViewController:

var imageLeftConstraint: NSLayoutConstraint?

在第一次创建约束时设置它:

imageLeftConstraint = self.imageView.leftAnchor.constraint(equalTo: button.leftAnchor, constant: 0)
imageLeftConstraint?.isActive = true

然后在添加新约束之前使用它来停用先前的约束:

@objc func didSelectedButton(_ button:UIButton) {
imageLeftConstraint?.isActive = false
imageLeftConstraint = self.imageView.leftAnchor.constraint(equalTo: button.leftAnchor)
imageLeftConstraint?.isActive = true
UIView.animate(withDuration: 1, animations: {
self.view.layoutIfNeeded()
}, completion: nil)
}

注意:您需要在 imageView 的 superView 上调用 layoutIfNeeded()(又名 self.view ) 因为 buttonimageView 之间的约束将添加到它们的共同祖先 (self.view)。

关于ios - 如何在swift中更新 anchor 约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54097046/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com