将 layoutMargins 添加到 UIStackView 中的一个元素
Add layoutMargins to one element in a UIStackView
我想创建一个包含 3 个元素的垂直堆栈视图。
我只想在第二个和最后一个元素之间多一点 space 。所以我考虑添加到最后一个元素:
mylastelement.layoutMargins = UIEdgeInsets(top:30, left:0,bottom:0, right:0)
但是布局边距没有应用到我的堆栈视图中。有什么简单的方法可以实现吗(我想避免修改最后一个元素的内部高度)。
编辑:我只是尝试通过以下方式增加其框架内的第二个元素高度(+50):
my2ndElementLabel.sizeToFit()
my2ndElementLabel.frame = CGRect(x:my2ndElementLabel.frame.origin.x,y:lmy2ndElementLabel.frame.origin.y,
width:my2ndElementLabel.frame.width, height:my2ndElementLabel.frame.height + 50)
但是没有效果。
EDIT2:我试图向我的 UIStackView 添加一个随机视图,但该视图被忽略了!可能在理解 UIKit 的工作原理时遗漏了一些东西?...:
let v = UIView(frame:CGRect(x:0,y:0,width:100,height:400))
v.backgroundColor = .red
myStackView.addArrangedSubview(v)
//...
我发现自己:看起来 UIStackView 对旧的大小调整系统(使用 .frame)根本不起作用。看来你必须限制高度和宽度,StackView 会在你添加 arrangedSubview 时为你限制 left/top/right/bottom 位置。
我的第二个视图是一个标签:我想要文本下方的边距为 40。所以我首先将标签高度计算到其 .frame 属性 中,并将高度限制在 frame.height + 40(= 我的边距)
labelDesc.sizeToFit()
labelDesc.heightAnchor.constraint(equalToConstant:40).isActive = true
但我发现我自己的解决方案非常丑陋。我确信 UIKit 提供了一种更好的方法来实现这样一个简单的目标,而无需制作这些 DIY 解决方案。因此,如果您习惯于使用 UIKit,请告诉我是否有更好的解决方案。
同样,您可以相对于嵌入视图的任何视图的相应边缘来约束视图的顶部(或底部)锚点。难看的是有点品味问题,我发现自动布局约束易于使用且易于推理。
来自 Mac OS 而不是 iOS 的简单示例:
let button = ControlFactory.labeledButton("Filter")
addSubview(button)
button.bottomAnchor.constraint(equalTo: bottomAnchor, constant: -20).isActive = true
button.centerXAnchor.constraint(equalTo: centerXAnchor).isActive = true
此特定代码存在于视图初始值设定项中,并将按钮放置在视图中间,距离底部 20 点。
这是我做的一个扩展,有助于快速实现这样的利润率:
extension UIStackView {
func addArrangedSubview(_ v:UIView, withMargin m:UIEdgeInsets )
{
let containerForMargin = UIView()
containerForMargin.addSubview(v)
v.translatesAutoresizingMaskIntoConstraints = false
NSLayoutConstraint.activate([
v.topAnchor.constraint(equalTo: containerForMargin.topAnchor, constant:m.top ),
v.bottomAnchor.constraint(equalTo: containerForMargin.bottomAnchor, constant: m.bottom ),
v.leftAnchor.constraint(equalTo: containerForMargin.leftAnchor, constant: m.left),
v.rightAnchor.constraint(equalTo: containerForMargin.rightAnchor, constant: m.right)
])
addArrangedSubview(containerForMargin)
}
}
您可以在第二个和第三个元素之间设置自定义间距。
myStackView.setCustomSpacing(30.0, after: my2ndElementLabel)
考虑根据需要在堆栈视图中插入 correctly-sized UIView 来添加“边距”。
如果您需要在 2 个特定元素之间留出 40 像素的边距...添加一个高度限制为 40 像素的 UIView。分配 clearColor
背景以使其不可见。
您可以将 IBOutlet 添加到此视图并像隐藏堆栈视图中的任何其他项目一样隐藏它。
我想创建一个包含 3 个元素的垂直堆栈视图。 我只想在第二个和最后一个元素之间多一点 space 。所以我考虑添加到最后一个元素:
mylastelement.layoutMargins = UIEdgeInsets(top:30, left:0,bottom:0, right:0)
但是布局边距没有应用到我的堆栈视图中。有什么简单的方法可以实现吗(我想避免修改最后一个元素的内部高度)。
编辑:我只是尝试通过以下方式增加其框架内的第二个元素高度(+50):
my2ndElementLabel.sizeToFit()
my2ndElementLabel.frame = CGRect(x:my2ndElementLabel.frame.origin.x,y:lmy2ndElementLabel.frame.origin.y,
width:my2ndElementLabel.frame.width, height:my2ndElementLabel.frame.height + 50)
但是没有效果。
EDIT2:我试图向我的 UIStackView 添加一个随机视图,但该视图被忽略了!可能在理解 UIKit 的工作原理时遗漏了一些东西?...:
let v = UIView(frame:CGRect(x:0,y:0,width:100,height:400))
v.backgroundColor = .red
myStackView.addArrangedSubview(v)
//...
我发现自己:看起来 UIStackView 对旧的大小调整系统(使用 .frame)根本不起作用。看来你必须限制高度和宽度,StackView 会在你添加 arrangedSubview 时为你限制 left/top/right/bottom 位置。
我的第二个视图是一个标签:我想要文本下方的边距为 40。所以我首先将标签高度计算到其 .frame 属性 中,并将高度限制在 frame.height + 40(= 我的边距)
labelDesc.sizeToFit()
labelDesc.heightAnchor.constraint(equalToConstant:40).isActive = true
但我发现我自己的解决方案非常丑陋。我确信 UIKit 提供了一种更好的方法来实现这样一个简单的目标,而无需制作这些 DIY 解决方案。因此,如果您习惯于使用 UIKit,请告诉我是否有更好的解决方案。
同样,您可以相对于嵌入视图的任何视图的相应边缘来约束视图的顶部(或底部)锚点。难看的是有点品味问题,我发现自动布局约束易于使用且易于推理。
来自 Mac OS 而不是 iOS 的简单示例:
let button = ControlFactory.labeledButton("Filter")
addSubview(button)
button.bottomAnchor.constraint(equalTo: bottomAnchor, constant: -20).isActive = true
button.centerXAnchor.constraint(equalTo: centerXAnchor).isActive = true
此特定代码存在于视图初始值设定项中,并将按钮放置在视图中间,距离底部 20 点。
这是我做的一个扩展,有助于快速实现这样的利润率:
extension UIStackView {
func addArrangedSubview(_ v:UIView, withMargin m:UIEdgeInsets )
{
let containerForMargin = UIView()
containerForMargin.addSubview(v)
v.translatesAutoresizingMaskIntoConstraints = false
NSLayoutConstraint.activate([
v.topAnchor.constraint(equalTo: containerForMargin.topAnchor, constant:m.top ),
v.bottomAnchor.constraint(equalTo: containerForMargin.bottomAnchor, constant: m.bottom ),
v.leftAnchor.constraint(equalTo: containerForMargin.leftAnchor, constant: m.left),
v.rightAnchor.constraint(equalTo: containerForMargin.rightAnchor, constant: m.right)
])
addArrangedSubview(containerForMargin)
}
}
您可以在第二个和第三个元素之间设置自定义间距。
myStackView.setCustomSpacing(30.0, after: my2ndElementLabel)
考虑根据需要在堆栈视图中插入 correctly-sized UIView 来添加“边距”。
如果您需要在 2 个特定元素之间留出 40 像素的边距...添加一个高度限制为 40 像素的 UIView。分配 clearColor
背景以使其不可见。
您可以将 IBOutlet 添加到此视图并像隐藏堆栈视图中的任何其他项目一样隐藏它。