bru*_*uno 1 anchor xcode constraints swift programmatically
为什么我必须给我的rigthAnchor约束一个负值才能titleLabel从视图的右侧产生 28 个边距。如果我只是给它正值,它会超出视图 28 个像素。
private func setupLayout() {
view.addSubview(imageView)
view.addSubview(titleLabel)
// *** imageView ***
if #available(iOS 11.0, *) {
imageView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 116).isActive = true
} else {
imageView.topAnchor.constraint(equalTo: view.topAnchor, constant: 116).isActive = true
}
imageView.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true
imageView.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true
imageView.heightAnchor.constraint(equalToConstant: 224).isActive = true
// *** titleLabel ***
titleLabel.topAnchor.constraint(equalTo: imageView.bottomAnchor, constant: 25).isActive = true
titleLabel.rightAnchor.constraint(equalTo: view.rightAnchor, constant: -28).isActive = true
titleLabel.leftAnchor.constraint(equalTo: view.leftAnchor, constant: 28).isActive = true
}
Run Code Online (Sandbox Code Playgroud)
因为按照这个
titlelbl.right = view.right - 28
Run Code Online (Sandbox Code Playgroud)
和说一样
view.right = titlelbl.right + 28
Run Code Online (Sandbox Code Playgroud)
firstItem.anchor = seconfItem.anchor * 乘数 +/- 常数
转化为
titleLabel.rightAnchor.constraint(equalTo: view.rightAnchor, constant: -28).isActive = true
Run Code Online (Sandbox Code Playgroud)
或者
view.rightAnchor.constraint(equalTo: titleLabel.rightAnchor, constant: 28).isActive = true
Run Code Online (Sandbox Code Playgroud)
如果你不喜欢负值
编辑:
约束为 -28 时的含义
您告诉自动布局将 titlelbl 的最大 x 值设置为等于视图的最大 x 值减去 28
| - 磅 + 28 - |
但+28
| - lbl - | + 28 <<< 视野外最大 x
| 归档时间: |
|
| 查看次数: |
1187 次 |
| 最近记录: |