ios - 将新 View 添加到层次结构时的自动布局问题
<p><p>当我有一个通过 IB 应用约束的 UIView 并将一个新的 UIView 添加到它的 View 层次结构中时,我在几个场景中苦苦挣扎。事情是这样的:</p>
<p>我有一个应用了以下约束的全屏 UITableView,因此它可以很好地适应 iOS 设备的所有分辨率:</p>
<p> <a href="/image/f8Eb1.png" rel="noreferrer noopener nofollow"><img src="/image/f8Eb1.png" alt="enter image description here"/></a> </p>
<p>现在我想在 UITableView 上方添加一个 UIView 作为一种工具栏。 </p>
<p>现在我成功添加此 View 的唯一可能方法是将其添加到 TableView 顶部,以便它覆盖 tableview 的顶部。我想要实现的是新添加的 UIView 向下推表,因此两者都是可见的。我尝试了几件事,包括在表格 View 上方的 IB 中添加一个容器 View ,但这根本不起作用。 </p>
<p>所以我的问题是:有没有一种方法可以动态地编辑、删除和添加新的约束到 View 层次结构,理想情况下支持动画?</p></p>
<br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
<p><p>您可以为约束创建 <code>IBOutlets</code>,就像任何 View 一样。
每个 <code>NSLayoutConstraint</code> 对象都有一个 <code>constant</code> 属性,您可以随时在代码中设置该属性(它是约束的值)。</p>
<p>因此,您将在 Interface Builder 上创建两个 View ,并将 TableView 的顶部约束到新 View 的底部。
新 View 将具有设置的高度约束,并且您创建该高度约束的导出以使该 View 在代码中出现或消失。
还有其他可能的解决方案,但我认为这是最简单的。</p>
<p>代码是这样的:</p>
<pre><code>@property (weak, nonatomic) IBOutlet NSLayoutConstraint *topHeightConstraint;
</code></pre>
<p>设置值:</p>
<pre><code>self.topHeightConstraint.constant = 60;
</code></pre>
<p>并对其进行动画处理:</p>
<pre><code>[UIView animateWithDuration:0.6 animations:^{
self.topHeightConstraint.constant = 60;
;
}];
</code></pre></p>
<p style="font-size: 20px;">关于ios - 将新 View 添加到层次结构时的自动布局问题,我们在Stack Overflow上找到一个类似的问题:
<a href="https://stackoverflow.com/questions/31638033/" rel="noreferrer noopener nofollow" style="color: red;">
https://stackoverflow.com/questions/31638033/
</a>
</p>
页:
[1]