gpt4 book ai didi

ios - 动画约束时高度 anchor 的自动布局错误

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

我需要在我的应用程序的页脚处呈现一个 UIView,当用户采取某种操作时,该 View 会滚动到 View 的顶部并固定在适当的位置。

想象一下几乎是一个标签栏 View 动画到导航栏中。

example of requirement

我基本上通过为我的 View 设置 2 个 anchor (顶部和底部)来模拟这一点。

然后我切换这些 anchor 并使用 UIView.animatelayoutIfNeeded 来移动位置。

然后我的组件的内容被锚定到父级的安全区域,这意味着我避免了 X 系列上的顶部和底部问题。

然而,当我的 View 开始动画时,我的终端出现了自动布局错误

(
"<NSLayoutConstraint:0x600002e38ff0 UILabel:0x7fe64bc04570'Foo Bar Boo Baz'.height == 44 (active)>",
"<NSLayoutConstraint:0x600002e38d70 UILabel:0x7fe64bc04570'Foo Bar Boo Baz'.top == UILayoutGuide:0x600003408d20'UIViewSafeAreaLayoutGuide'.top (active)>",
"<NSLayoutConstraint:0x600002e38e10 UILabel:0x7fe64bc04570'Foo Bar Boo Baz'.bottom == UILayoutGuide:0x600003408d20'UIViewSafeAreaLayoutGuide'.bottom (active)>",
"<NSLayoutConstraint:0x600002e39130 UIView:0x7fe64bc166b0.bottom == Home.AnimatedCustomNavigationView:0x7fe64bc02970.bottom (active)>",
"<NSLayoutConstraint:0x600002e390e0 V:|-(0)-[UIView:0x7fe64bc166b0] (active, names: '|':Home.AnimatedCustomNavigationView:0x7fe64bc02970 )>",
"<NSLayoutConstraint:0x600002e41810 'UIView-Encapsulated-Layout-Height' Home.AnimatedCustomNavigationView:0x7fe64bc02970.height == 896 (active)>",
"<NSLayoutConstraint:0x600002e38cd0 'UIViewSafeAreaLayoutGuide-bottom' V:[UILayoutGuide:0x600003408d20'UIViewSafeAreaLayoutGuide']-(34)-| (active, names: '|':UIView:0x7fe64bc166b0 )>",
"<NSLayoutConstraint:0x600002e38c30 'UIViewSafeAreaLayoutGuide-top' V:|-(0)-[UILayoutGuide:0x600003408d20'UIViewSafeAreaLayoutGuide'] (active, names: '|':UIView:0x7fe64bc166b0 )>"
)

Will attempt to recover by breaking constraint
<NSLayoutConstraint:0x600002e38ff0 UILabel:0x7fe64bc04570'Foo Bar Boo Baz'.height == 44 (active)>

这似乎是由高度 anchor 引起的。

我不确定如何实现此效果并修复此错误。

import UIKit

class AnimatedCustomNavigationView: UIView {

private lazy var navBar = UIView(frame: .zero)

private var navBarTopAnchor: NSLayoutConstraint!
private var navBarBottomAnchor: NSLayoutConstraint!

override init(frame: CGRect) {
super.init(frame: frame)

backgroundColor = theme.color(.background)
navBar.backgroundColor = .purple

let label = UILabel(frame: .zero)
label.text = "Foo Bar Boo Baz"
label.sizeToFit()


addSubview(navBar)
navBar.addSubview(label)

[navBar, label].forEach { $0.translatesAutoresizingMaskIntoConstraints = false }

NSLayoutConstraint.activate([

// MARK: - NavBar Container

navBar.leadingAnchor.constraint(equalTo: self.leadingAnchor),
navBar.trailingAnchor.constraint(equalTo: self.trailingAnchor),


// MARK: - Label

label.topAnchor.constraint(equalTo: navBar.safeAreaLayoutGuide.topAnchor),
label.leadingAnchor.constraint(equalTo: navBar.leadingAnchor, constant: 16),
label.bottomAnchor.constraint(equalTo: navBar.safeAreaLayoutGuide.bottomAnchor),
label.trailingAnchor.constraint(equalTo: navBar.trailingAnchor, constant: -16),

label.heightAnchor.constraint(equalToConstant: 44)
])

navBarTopAnchor = navBar.topAnchor.constraint(equalTo: topAnchor)
navBarTopAnchor.isActive = false

navBarBottomAnchor = navBar.bottomAnchor.constraint(equalTo: bottomAnchor)
navBarBottomAnchor.isActive = true



DispatchQueue.main.asyncAfter(deadline: .now() + 2) {
self.navBarTopAnchor.isActive = true
self.navBarBottomAnchor.isActive = false
UIView.animate(withDuration: 1.5, delay: 0, options: .curveEaseInOut, animations: {
self.layoutIfNeeded()
}, completion: nil)
}
}

required init?(coder aDecoder: NSCoder) {
return nil
}
}

现在为了模拟用户操作,我将动画调用包装在 DispatchQueue.main.asyncAfter

最佳答案

您需要正确排序 .isActive = false 应该在 .isActive = true 之前

DispatchQueue.main.asyncAfter(deadline: .now() + 2) {  
self.navBarBottomAnchor.isActive = false
self.navBarTopAnchor.isActive = true
UIView.animate(withDuration: 1.5, delay: 0, options: .curveEaseInOut, animations: {
self.layoutIfNeeded()
}, completion: nil)
}

关于ios - 动画约束时高度 anchor 的自动布局错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56869965/

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