Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/ios/105.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/swift/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ios 为什么在集合视图的最后一个单元格结束后,我会获得额外的空间?_Ios_Swift - Fatal编程技术网

Ios 为什么在集合视图的最后一个单元格结束后,我会获得额外的空间?

Ios 为什么在集合视图的最后一个单元格结束后,我会获得额外的空间?,ios,swift,Ios,Swift,在我的收藏视图中,我在最后一个单元格的末尾获得了额外的空间。 如果单元数量增加,空间也会增加。 集合视图的背景色为黄色。我怎样才能阻止这个额外的空间? 在第二幅图像中,单元格的高度和宽度是集合视图的一半 r] 这是我的ViewController.swift文件代码 import UIKit class ViewController: UIViewController ,UICollectionViewDataSource,UICollectionViewDelegate,UICollecti

在我的收藏视图中,我在最后一个单元格的末尾获得了额外的空间。 如果单元数量增加,空间也会增加。 集合视图的背景色为黄色。我怎样才能阻止这个额外的空间? 在第二幅图像中,单元格的高度和宽度是集合视图的一半

r]

这是我的ViewController.swift文件代码

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