- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
当我尝试使用 UIStackView
时,XCode 抛出以下约束错误:
(
"<NSAutoresizingMaskLayoutConstraint:0x7f87a1dfa360 h=--& v=--& V:[UIStackView:0x7f87a6403a00(0)]>",
"<NSLayoutConstraint:0x7f87a6410590 'UISV-canvas-connection' UIStackView:0x7f87a6403a00.top == UIView:0x7f87a6409630.top>",
"<NSLayoutConstraint:0x7f87a6444170 'UISV-canvas-connection' V:[UIView:0x7f87a644d790]-(0)-| (Names: '|':UIStackView:0x7f87a6403a00 )>",
"<NSLayoutConstraint:0x7f87a645bec0 'UISV-fill-equally' UIView:0x7f87a6407a10.height == UIView:0x7f87a6409630.height>",
"<NSLayoutConstraint:0x7f87a6458f40 'UISV-fill-equally' UIView:0x7f87a644d790.height == UIView:0x7f87a6409630.height>",
"<NSLayoutConstraint:0x7f87a64306d0 'UISV-spacing' V:[UIView:0x7f87a6409630]-(5)-[UIView:0x7f87a6407a10]>",
"<NSLayoutConstraint:0x7f87a643bea0 'UISV-spacing' V:[UIView:0x7f87a6407a10]-(5)-[UIView:0x7f87a644d790]>"
)
Will attempt to recover by breaking constraint
<NSLayoutConstraint:0x7f87a643bea0 'UISV-spacing' V:[UIView:0x7f87a6407a10]-(5)-[UIView:0x7f87a644d790]>
我的 View Controller 如下:
public class ExampleController: UIViewController {
let v1 = UIView(frame: CGRect(x: 0, y: 0, width: 250, height: 100))
let v2 = UIView(frame: CGRect(x: 0, y: 0, width: 250, height: 300))
let v3 = UIView(frame: CGRect(x: 0, y: 0, width: 250, height: 200))
let parent1 = UIStackView()
public override func viewDidLoad() {
super.viewDidLoad()
v1.backgroundColor = .red
v2.backgroundColor = .green
v3.backgroundColor = .blue
parent1.axis = .vertical
parent1.distribution = .fillEqually
parent1.spacing = 5 // TODO: This causes the error!
parent1.addArrangedSubview(v1)
parent1.addArrangedSubview(v2)
parent1.addArrangedSubview(v3)
view.addSubview(parent1)
}
// MARK: Constraints
private var didUpdateConstraints = false
override public func updateViewConstraints() {
if !didUpdateConstraints {
parent1.snp.makeConstraints { (make) -> Void in
make.edges.equalToSuperview()
}
didUpdateConstraints = true
}
super.updateViewConstraints()
}
}
堆栈 View 的分布似乎没有什么不同。每当设置间距时,我都会收到错误消息。
与我的约束有什么冲突?
什么是UISV-canvas-connection
?
最佳答案
它实际上并没有因为间距而断裂。它因为您创建 View 的方式而中断 :D
当你创建一个像...这样的 View 时
let v1 = UIView(frame: CGRect(x: 0, y: 0, width: 250, height: 100))
当 View 被布局时,它会添加一组默认的约束。 UIStackView
也是如此。
当你创建它时...
let parent1 = UIStackView()
它获得一个 (0, 0, 0, 0) 的框架,然后向其添加约束以保持该框架的位置和高度。
你得到的错误是因为堆栈 View 的高度和宽度。
<NSAutoresizingMaskLayoutConstraint:0x7f87a1dfa360 h=--& v=--& V:[UIStackView:0x7f87a6403a00(0)]>
这一行指的是那些“自动”约束。
您最好的选择是使用约束重新创建 View 的宽度和高度。
像这样...
// using this format means you can create the view and add all the
// other config to it at the same time
let v1: UIView = {
let u = UIView()
// this line stops the "automatic" constraints being added
u.translatesAutoresizingMaskIntoConstraints = false
u.backgroundColor = .red
// now you have to add your own constraints though
u.heightAnchor.constraint(equalToConstant: 100).isActive = true
u.widthAnchor.constraint(equalToConstant: 250).isActive = true
return u
}()
let v2: UIView = {
let u = UIView()
u.translatesAutoresizingMaskIntoConstraints = false
u.backgroundColor = .green
u.heightAnchor.constraint(equalToConstant: 100).isActive = true
u.widthAnchor.constraint(equalToConstant: 250).isActive = true
return u
}()
let v3: UIView = {
let u = UIView()
u.translatesAutoresizingMaskIntoConstraints = false
u.backgroundColor = .blue
u.heightAnchor.constraint(equalToConstant: 100).isActive = true
u.widthAnchor.constraint(equalToConstant: 250).isActive = true
return u
}()
let parent1: UIStackView = {
let s = UIStackView()
s.translatesAutoresizingMaskIntoConstraints = false
s.spacing = 5
s.axis = .vertical
s.distirbution = .fillEqually
return s
}()
public override func viewDidLoad() {
super.viewDidLoad()
// I moved all the config stuff into the creation of each view...
// No need to have them here.
parent1.addArrangedSubview(v1)
parent1.addArrangedSubview(v2)
parent1.addArrangedSubview(v3)
view.addSubview(parent1)
}
您正在堆栈 View 中使用 .fillEqually
。这将使每个 View 的高度彼此相等。这将与您添加到它们的高度约束冲突。也许您应该完全移除每个 View 的约束,让堆栈 View 进行布局。
像这样...
let v2: UIView = {
let u = UIView()
u.translatesAutoresizingMaskIntoConstraints = false
u.backgroundColor = .green
return u
}()
关于ios - 设置间距时 UIStackView 的约束会中断,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41762349/
这个问题在这里已经有了答案: Why should there be spaces around '[' and ']' in Bash? (4 个回答) 3年前关闭。 作为初学者,我没有在任何地方找
我有一个程序,我在其中输入 Java 程序来检查输入的字符串是否为回文。我有 2 个问题正在发生,我似乎一辈子都无法解决。 我已经输入了代码,这样它会告诉我它是否是一个回文,当所有小写字母不涉及空格时
table { border: 0; padding: 0; border-collapse: collapse;
我有 10 个单元格,其中第 6 个单元格的宽度必须与其他单元格不同。我试图在流委托(delegate)方法中更改它。但是从第 7 个单元格到第 10 个单元格的间距出了点问题。 func coll
我只是希望将这些新闻发布很好地隔开,以便在每次发布之间留出空隙。我在下面附上了一张图片来解释。我试图增加下面的填充,但这没有用。感谢您的帮助 .headline { position: absolut
如何使用 css 删除表格结构中烦人的单元格间距和/或填充?如果解决方案在 IE7-9、Firefox 和 Chrome 中有效,请加倍支持! 为什么CSS这么难!真让人抓狂! 最佳答案 通常,在该表
我在我正在使用的网站上设置了按钮。我想在按钮外创建一个 2px 的边框,有一点间距。请参见设计图像。 我可以创建边框,但不能创建边框之外的间距。这是当前的开发站点。按钮是第一个图形。 到目前为止我已经
我正在网站上生成元素符号列表(通过使用 jquery 自动完成功能)和我在网站中使用响应式网页设计。 我想在每个列表项后留一个空格。为此,我添加了以下 CSS: li { margin-b
我在格式化我的 HTML 页面时遇到困难。 正如您从源代码中看到的那样,它是一个表格,其中每一行都包含由我的网络应用程序动态填充的格式化记录列表。如果其中一列有空值,我想保留行的格式,所以我基本上应该
我一直致力于设计一个具有三个链接的跨移动设备宽度的设计。我不明白为什么我不能得到正确的间距。什么看起来不对劲? 设计如下: 下面是编码版本的样子: 这是我的 CSS: .b-nav-Wrapper {
我需要在 matplotlib 中生成一大堆垂直堆叠的图。结果将使用 savefig 保存并在网页上查看,所以我不在乎最终图像有多高,只要子图间隔开,这样它们就不会重叠。 无论我允许这个数字有多大,子
我需要在 matplotlib 中生成一大堆垂直堆叠的图。结果将使用 savefig 保存并在网页上查看,所以我不在乎最终图像有多高,只要子图之间有间距,不重叠即可。 无论我允许图有多大,子图似乎总是
是否可以在 BorderPane 上设置节点之间的间距? ? Swing 等效项将是 BorderLayout 上的 hgap 和 vgap . 我在文档中没有找到任何内容,我能想到的唯一可行的解
我有一个基于日历的应用 我希望用户能够通过捏合来放大和缩小日历。这是我的代码: let p = UIPinchGestureRecognizer(target: self, action: #sele
我在为 Android 编写一段代码时遇到问题。我使用的是eclipse开发环境。我想要完成的是将一周中的日子均匀地分布在表格的第一行(有六行)。我不知道如何才能使这些单词真正散开,而不是仅仅粘在一起
我有一个基于日历的应用 我希望用户能够通过捏合来放大和缩小日历。这是我的代码: let p = UIPinchGestureRecognizer(target: self, action: #sele
我该怎么做才能对齐此代码中的所有列?这是正确的还是......? import urllib.request from re import findall def determinarLlegadas
当使用垂直对齐的 BoxLayout 时,如何阻止组件随着包含的 JFrame 的增长而扩展,从而在底部留下额外的空间?我尝试了不同的布局,但很快就变得一团糟。我还尝试在面板底部添加胶水,但布局管理器
我正在尝试制作 cout #include int main() { std::cout << setw(4) << 1 << setw(4) << 2 << std::endl; } 输出
使用示例 http://developer.android.com/guide/tutorials/views/hello-tabwidget.html通过向布局添加 HorizontalScro
我是一名优秀的程序员,十分优秀!