ios - 设置自定义 UIView 的不同水平对齐方式
问题描述
创建了一个自定义 UIView 'MyLabelView',其中包含两个元素,1x UILabel,1x UIView,它们将被设置为背景颜色。
MyLabelView
查看:代码:
import UIKit
@IBDesignable
class MyLabelView: UIView {
@IBOutlet var contentView: UIView!
@IBOutlet weak var imageView: UIView!
@IBOutlet weak var titleLabel: UILabel!
override init(frame: CGRect) {
super.init(frame: frame)
commonInit()
}
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
commonInit()
}
override func prepareForInterfaceBuilder() {
super.prepareForInterfaceBuilder()
commonInit()
contentView?.prepareForInterfaceBuilder()
}
private func commonInit() {
let bundle = Bundle(for: type(of: self))
bundle.loadNibNamed(String(describing: type(of: self)), owner: self, options: nil)
addSubview(contentView)
}
}
我在两种情况下使用 MyLabelView:
- MasterViewController(带有动态原型的 TableViewController)
- DetailViewController(带有静态单元格和分组样式的 TableViewController)
MasterViewController
将 MyLabelView 正确显示为自定义 UITableViewCell
视图的一部分:代码(在 cellForRowAt 中):
let cell: MyTableViewCell = tableView.dequeueReusableCell(withIdentifier: "MyTableViewCell") as! MyTableViewCell
cell.myLabelView.titleLabel.text = "Label"
cell.myLabelView.imageView.backgroundColor = UIColor.red
// Dynamic width to fit label texts of various sizes
var frm: CGRect = cell.myLabelView.titleLabel.frame
frm.size.width = cell.myLabelView.titleLabel.intrinsicContentSize.width
cell.myLabelView.titleLabel.frame = frm
DetailViewController
在这里我想渲染 MyLabelView 增加字体大小(工作)和右对齐,这样无论标签文本有多长,它总是与人字形
视图对齐:代码(在 viewDidLoad 中):
myLabelView.titleLabel.text = "Label"
myLabelView.titleLabel.font = myLabelView.titleLabel.font.withSize(17)
myLabelView.imageView.backgroundColor = UIColor.red
// Dynamic width to fit label texts of various sizes
var frm: CGRect = myLabelView.titleLabel.frame
frm.size.width = myLabelView.titleLabel.intrinsicContentSize.width
myLabelView.titleLabel.frame = frm
预期结果
视图:视图:我尝试使用额外的外部 UIViews 作为容器并使用 AutoLayout,但不知何故它从来没有像我预期的那样工作。非常感谢您的帮助。Swift 4,iOS11
更新
我尝试在 IB 中设置约束,因为我无法访问单元格(使用静态单元格)。内容视图:标题:MyLabelView:
解决方案
只需在 UITableViewCell 子类中添加一个函数,并在需要设置右侧旁边的视图时调用它:
func setTrailingAnchorForView() {
contentView.translatesAutoresizingMaskIntoConstraints = false
contentView.centerXAnchor.constraint(equalTo: self.centerXAnchor).isActive = true
contentView.trailingAnchor.constraint(equalTo: imageView.leadingAnchor, constant: 0).isActive = true
}
像这样称呼它:
cell.setTrailingAnchorForView()
推荐阅读
- c++ - 使用 CMake 将其他依赖项和库目录链接到静态库项目
- templates - 如何将信息框移到一边?
- python - Python Plotly 用文本注释多个变量
- python - tensorflow 的 Dataset.list_files 函数中的“/*/*”是什么意思?
- python - 衡量运行时最佳实践 (Python)
- git - 在 GitHub 拉取请求中更改提交消息
- java - 如何在 IntelliJ 中显示文件结构(意外删除后)
- reactjs - 反应:你怎么知道哪个变量导致 componentDidUpdate() 被触发?
- sql - 将月费率除以日记录在SQL Server中基于getdate()和会计闰年的查询
- typescript - 映射保留参数类型的函数数组。TypeScript v4 中的可变元组类型可以改善这一点吗?