自动布局:删除视图时相邻视图的后备约束
Posted
技术标签:
【中文标题】自动布局:删除视图时相邻视图的后备约束【英文标题】:Autolayout: Fallback constraints for neighbouring views when removing a view 【发布时间】:2015-02-27 09:06:30 【问题描述】:我正在尝试在 UICollectionReusableView (UICollectionView Header) 上下文中进行这项工作。
UILabels A、B 和 C 中的字符串所需的高度被计算并设置为灰色视图的高度,有点像这样:
- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout referenceSizeForHeaderInSection:(NSInteger)section
....
CGFloat expectedHeightForLabelB = 0;
if (stringB.length > 0)
expectedHeightForLabelB = 8 + calculatedRequiredHeightForStringB;
....
CGFloat expectedHeaderHeight = expectedHeightForLabelA + expectedHeightForLabelB + expectedHeightForLabelC + 8
return CGSizeMake(collectionView.bounds.size.width, expectedHeaderHeight);
在
collectionView:viewForSupplementaryElementOfKind:atIndexPath:
,我有一个条件
if (stringB.length == 0)
[headerView.labelB removeFromSuperView];
在这种情况下,我已经解决了灰色超级视图的估计动态高度。我希望 UILabel A 和 C 有一个 8 pts 的后备垂直约束。
我只能想到 2 种可能的(不确定是对还是错)方法来实现这一点。
以编程方式在
collectionView:viewForSupplementaryElementOfKind:atIndexPath:
的代码中应用新的后备布局。
在情节提要中设置具有常量 8 和更低优先级的约束。
实现这一目标的正确或最佳方法是什么?我已经看到了here 的答案,但如果有的话,我想收集更强大的输入。
提前致谢!
【问题讨论】:
【参考方案1】:取一个 B 的高度约束和 A 和 B 之间的垂直空间的 IBOutlet 并将其更改为 0 而不是删除视图
希望这能解决你的问题
【讨论】:
嗨,我在示例图片中犯了一个错误,因为标签上不应该有任何高度限制,因为它们的高度应该是动态的。但我明白你的想法,并会尝试操纵标签本身的高度。尝试此解决方案后将在此处更新。谢谢! @Ryan 如果高度是动态的,那么如果标签中没有文本,则默认情况下高度将为零。以上是关于自动布局:删除视图时相邻视图的后备约束的主要内容,如果未能解决你的问题,请参考以下文章