我有一个 KSSection
UIView
子类,我试图用它来折叠/展开不同的部分。它有一个名为 content
的 subview (由 IBOutlet
设置)。 content
的大小由多个大小可变的 subview (UILabel
、UIImageView
等)决定。
目前,我将 content
的前导和尾随空格固定到父 KSSection
,将其垂直居中对齐,并添加 在运行时删除
约束 content
和 section
的高度相等。如果我禁用在运行时删除
,一切都很好——除了我无法折叠 View 。
如何计算要用作 KSection
的 intrinsicContentSize
的 content
的大小?到目前为止,我有以下代码片段,但是对 intrinsicContentSize
的调用总是为两个属性返回 UIViewNoIntrinsicMetric
。
@implementation SKContainer
- (CGSize)intrinsicContentSize
{
if (self.collapsed) return CGSizeZero;
else return [self.content intrinsicContentSize];
}
- (void)layoutSubviews
{
[super layoutSubviews];
[self invalidateIntrinsicContentSize];
}
- (void)setCollapsed:(BOOL)collapsed
{
if (_collapsed != collapsed)
{
_collapsed = collapsed;
[self invalidateIntrinsicContentSize];
}
}
@end
编辑:
很抱歉澄清它实际上是为 CGSize
的两个维度返回 UIViewNoIntrinsicMetric
。
最佳答案
好吧,所以我之前的回答是在不必要的轨道上。我最终做的是这样的:
首先,我完全删除了部分 View ,只留下普通的内容 View 来扮演部分的角色。 (剖面图只是增加了一层额外的复杂性。)然后我将剖面图高度的优先级降低到 250,然后运行该项目。急!剖面 View 现在完全由其自身展开,由其中的标签约束驱动。
其次,这是我折叠和展开的方式。我保留了两个约束的导出:截面高度约束和内部约束高度堆栈中的最后一个约束。然后我的展开/折叠代码如下所示:
- (IBAction)toggleButtonSelector:(id)sender
{
self.collapsed = !self.collapsed;
if (self.collapsed) {
self.sectionHeightConstraint.constant = 10; // or whatever height you like
self.sectionHeightConstraint.priority = 999;
[NSLayoutConstraint deactivateConstraints:@[self.bottomInternalConstraint]];
} else {
self.sectionHeightConstraint.priority = 250;
[NSLayoutConstraint activateConstraints:@[self.bottomInternalConstraint]];
}
}
你看,我们需要克服内部约束堆栈让我们保持扩展的愿望,所以我们移除其中一个约束以便折叠,我们将高度约束设置为一个较小的数字并提高其优先级。为了扩展,我们将其反转:我们恢复丢失的内部约束,并再次降低整体截面高度约束的优先级。
编辑这个实现的一个非常酷的副产品是我们现在可以通过在该方法的末尾附加这些代码行来制作折叠/展开效果的动画:
[UIView animateWithDuration:1 animations:^{
[self.view layoutIfNeeded];
}];
关于ios - 自动布局确定 subview 的大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29711969/