Ios 为什么在集合视图的最后一个单元格结束后,我会获得额外的空间?
在我的收藏视图中,我在最后一个单元格的末尾获得了额外的空间。 如果单元数量增加,空间也会增加。 集合视图的背景色为黄色。我怎样才能阻止这个额外的空间? 在第二幅图像中,单元格的高度和宽度是集合视图的一半 r] 这是我的ViewController.swift文件代码Ios 为什么在集合视图的最后一个单元格结束后,我会获得额外的空间?,ios,swift,Ios,Swift,在我的收藏视图中,我在最后一个单元格的末尾获得了额外的空间。 如果单元数量增加,空间也会增加。 集合视图的背景色为黄色。我怎样才能阻止这个额外的空间? 在第二幅图像中,单元格的高度和宽度是集合视图的一半 r] 这是我的ViewController.swift文件代码 import UIKit class ViewController: UIViewController ,UICollectionViewDataSource,UICollectionViewDelegate,UICollecti
import UIKit
class ViewController: UIViewController ,UICollectionViewDataSource,UICollectionViewDelegate,UICollectionViewDelegateFlowLayout{
@IBOutlet weak var collectionview: UICollectionView!
@IBOutlet weak var pagecontrol: UIPageControl!
@IBOutlet weak var VarBtnGet: UIButton!
@IBOutlet var MainView: UIView!
@IBOutlet weak var ScrollView: UIScrollView!
@IBOutlet weak var SubScrollView: UIView!
override func viewDidLoad() {
super.viewDidLoad()
btnsetuplayout()
pagecontrolsetup()
collectionview.dataSource = self
collectionview.delegate = self
collectionviewsetup()
}
func numberOfSections(in collectionView: UICollectionView) -> Int {
return 1
}
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 5
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell
{
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "CollectionCell", for: indexPath)
cell.backgroundColor = indexPath.item % 2 == 0 ? .green : .red
return cell
}
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
return CGSize(width: collectionview.frame.width, height: collectionview.frame.height)
}
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat {
return 0
}
func btnsetuplayout()
{
VarBtnGet.translatesAutoresizingMaskIntoConstraints = false
VarBtnGet.bottomAnchor.constraint(equalTo:SubScrollView.bottomAnchor,constant: -5).isActive = true
VarBtnGet.leftAnchor.constraint(equalTo: SubScrollView.leftAnchor ,constant: 0
).isActive = true
VarBtnGet.rightAnchor.constraint(equalTo: SubScrollView.rightAnchor,constant: 0).isActive = true
}
func pagecontrolsetup()
{
pagecontrol.translatesAutoresizingMaskIntoConstraints = false
pagecontrol.bottomAnchor.constraint(equalTo: VarBtnGet.topAnchor,constant: -100 ).isActive = true
pagecontrol.centerXAnchor.constraint(equalTo: SubScrollView.centerXAnchor).isActive = true
pagecontrol.backgroundColor = .brown
}
func collectionviewsetup()
{
collectionview.translatesAutoresizingMaskIntoConstraints = false
collectionview.isPagingEnabled = true
// collectionview.frame = CGRect.zero
if let layout = collectionview.collectionViewLayout as? UICollectionViewFlowLayout {
layout.scrollDirection = .horizontal
}
collectionview.backgroundColor = .yellow
collectionview.topAnchor.constraint(equalTo : SubScrollView.topAnchor ,constant: 5 ).isActive = true
collectionview.heightAnchor.constraint(equalTo: SubScrollView.heightAnchor,multiplier: 0.5).isActive = true
collectionview.widthAnchor.constraint(equalTo:SubScrollView.widthAnchor).isActive = true
//collectionview.leftAnchor.constraint(equalTo: SubScrollView.leftAnchor,constant: 5) .isActive=true
//collectionview.rightAnchor.constraint(equalTo: SubScrollView.rightAnchor,constant: -5) .isActive=true
}
@IBAction func ButtonGet(_ sender: Any) {
}
}
您是否检查了项目之间的最小间距,并使用将其设置为
0
?它默认为10.0
,因此可以解释您看到的内容。我看到您将行距设置为0
,这很好。我知道这是一篇旧文章,但我也遇到了同样的问题,我找到了解决方案。我希望这个答案能对某些人有所帮助。在我的例子中,我解决了将集合视图属性估计大小从自动更改为无的问题。就我而言,这解决了问题
使用故事板将“估计大小”设置为“无”,以使其正常工作。如果您不进行设置,则下面的代码将无法按预期工作。请查看:嘿,皮尤斯!你找到解决办法了吗?其实我也面临着同样的问题。嗨,皮尤斯,你找到解决这个问题的办法了吗?我也有同样的问题,但我不知道如何解决。是的,我已将其设置为0,但我在最后一个单元格的末尾获得了空间,而不是在它们之间。您是否已将
部分插入设置为可能为非零?您是否添加了带有视图的章节页眉或页脚,以供类似的SupplementalElement
?