[英]how to reduce/remove the left/right hand margin in a grouped UITableView?
[英]How to set left and right margin for UITableView in Swift
我在我的 controller 中使用UITableView ,它显示带有一些信息(标题、副标题和图像)的单元格。 我想为tableView添加一些填充,但我找不到正确的解决方案。 这是我的表格视图代码:
private let tableView: UITableView = {
let tableView = UITableView(frame: .zero, style: .grouped)
tableView.translatesAutoresizingMaskIntoConstraints = false
tableView.backgroundColor = .clear
tableView.separatorStyle = .none
tableView.allowsSelection = false
tableView.showsVerticalScrollIndicator = false
tableView.estimatedRowHeight = 44.0
tableView.rowHeight = UITableView.automaticDimension
return tableView
}()
在viewDidLoad()里面我为那个tableView设置了约束
NSLayoutConstraint.activate([
tableView.leadingAnchor.constraint(equalTo: view.leadingAnchor),
tableView.trailingAnchor.constraint(equalTo: view.trailingAnchor),
tableView.topAnchor.constraint(equalTo: view.topAnchor),
tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor)
])
现在我的观点是这样的:
现在,当我尝试通过添加以下内容在tableView闭包中配置contentInset属性时:
tableView.contentInset = .init(top: 0, left: 23.5, bottom: 0, right: -23.5)
如您所见,它仅在左侧增加了空间,但是查看调试视图层次结构,我可以说它将该contentView移到了右侧(它仍然具有与其父视图相同的宽度)
来自视图调试器的信息。 表视图:
<UITableView: 0x7fba82016000; frame = (0 0; 390 844); clipsToBounds = YES; gestureRecognizers = <NSArray: 0x60000023de90>; layer = <CALayer: 0x600000c4b9e0>; contentOffset: {-23.333333333333332, -47}; contentSize: {390, 635.66666666666663}; adjustedContentInset: {47, 23.5, 34, -23.5}; dataSource: <Myapp.WelcomeViewController: 0x7fba81c08f60>>
和第一个单元格:
<UITableViewCellContentView: 0x7fba84021250; frame = (0 0; 390 87); gestureRecognizers = <NSArray: 0x6000002cf900>; layer = <CALayer: 0x600000c2b900>>
TableView与单元格具有相同的宽度(390 对 390)。 如何在tableView的左侧和右侧添加我的填充,而不对该tableView进行限制(我希望该区域也可以滚动)
您可以通过在单元格的contentView
上设置.layoutMargins
来执行此操作(在单元格 class 本身或在cellForRowAt
中:
cell.contentView.layoutMargins = .init(top: 0.0, left: 23.5, bottom: 0.0, right: 23.5)
或在表格视图本身上:
override func viewDidLoad() {
super.viewDidLoad()
tableView.layoutMargins = .init(top: 0.0, left: 23.5, bottom: 0.0, right: 23.5)
// if you want the separator lines to follow the content width
tableView.separatorInset = tableView.layoutMargins
}
你可以试试这个:
在添加约束的同时添加常量
NSLayoutConstraint.activate([
tableView.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: 20),
tableView.trailingAnchor.constraint(equalTo: view.trailingAnchor, constant: 20),
tableView.topAnchor.constraint(equalTo: view.topAnchor),
tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor)
])
尝试这个
override var frame: CGRect {
get {
return super.frame
}
set (newFrame) {
var frame = newFrame
frame.origin.x += 10
frame.size.width -= 2 * 10
super.frame = frame
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.