集合视图组合布局,估计高度不起作用 [英] Collection View Compositional Layout with estimated height not working
问题描述
我希望我的应用针对每个可访问性选项(包括文字大小)进行优化.
I want my app to be optimized for every accessibility options including the text size.
我根据具有合成布局的部分制作了collectionView布局.因此,我需要细胞的高度随内容的增长而增长.我以为使用.estimated(constant)
可以完成工作,但似乎不起作用.内在的约束对我来说似乎很好.
I made a collectionView layout based on sections with a compositional layout. So I need my cell's height to grow with it's content. I thought using .estimated(constant)
would do the job but it doesn't seem to work. The inner constraints seems good to me.
这是我正在使用的布局:
Here is the layout I'm working with :
let size = NSCollectionLayoutSize(widthDimension: .fractionalWidth(0.42), heightDimension: .estimated(90))
let item = NSCollectionLayoutItem(layoutSize: NSCollectionLayoutSize(widthDimension: .fractionalWidth(1.0), heightDimension: .estimated(90)))
item.contentInsets = NSDirectionalEdgeInsets(top: 5.0, leading: 12.0, bottom: 5.0, trailing: 12.0)
let group = NSCollectionLayoutGroup.vertical(layoutSize: size, subitem: item, count: 1)
let section = NSCollectionLayoutSection(group: group)
section.contentInsets = NSDirectionalEdgeInsets(top: 0.0, leading: 6.0, bottom: 0.0, trailing: 0.0)
section.orthogonalScrollingBehavior = .groupPaging
当我在辅助功能设置中设置较大的文本大小时,会发生以下情况:
When I set a higher text size on the accessibility settings here is what happens :
该单元格应该包含2个标签,这里是autoLayoutConstraints:
The cell is supposed to contain 2 labels here is the autoLayoutConstraints :
NSLayoutConstraint.activate([
self.titleLabel.topAnchor.constraint(equalTo: self.container.topAnchor, constant: 10),
self.titleLabel.leftAnchor.constraint(equalTo: self.container.leftAnchor, constant: 20),
self.titleLabel.rightAnchor.constraint(equalTo: self.container.rightAnchor, constant: -20)
])
NSLayoutConstraint.activate([
self.subtitleLabel.topAnchor.constraint(equalTo: self.titleLabel.bottomAnchor, constant: 10),
self.subtitleLabel.leftAnchor.constraint(equalTo: self.container.leftAnchor, constant: 20),
self.subtitleLabel.rightAnchor.constraint(equalTo: self.container.rightAnchor, constant: -20),
self.subtitleLabel.bottomAnchor.constraint(equalTo: self.container.bottomAnchor, constant: -10)
])
预先感谢您的帮助.
推荐答案
我发现将LayoutGroup设置为水平而不是垂直可解决了该问题.这是我的最终布局:
I found that making my LayoutGroup horizontal instead of vertical fixed the issue. Here is my final layout :
let estimatedHeight = CGFloat(100)
let layoutSize = NSCollectionLayoutSize(widthDimension: .estimated(200), heightDimension: .estimated(estimatedHeight))
let item = NSCollectionLayoutItem(layoutSize: layoutSize)
let group = NSCollectionLayoutGroup.horizontal(layoutSize: layoutSize, subitem: item, count: 1)
let section = NSCollectionLayoutSection(group: group)
section.contentInsets = NSDirectionalEdgeInsets(top: 10, leading: 10, bottom: 10, trailing: 10)
section.interGroupSpacing = 10
section.orthogonalScrollingBehavior = .groupPaging
希望这会有所帮助^^
Hope it'll help ^^
这篇关于集合视图组合布局,估计高度不起作用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!