编辑CollectionViewCell的宽度

时间:2017-08-13 23:46:05

标签: ios swift uicollectionview uicollectionviewcell collectionview

我正在尝试编辑单元格的宽度,这样无论屏幕尺寸如何,我都会连续with个单元格。我用于Collection View的代码如下:

score1.count

这是针对单元格宽度的函数。

func numberOfSections(in collectionView: UICollectionView) -> Int {
    return 1
}
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    return self.items.count
}

func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath as IndexPath) as! MyCollectionViewCell

    cell.myLabel.text = String(self.items[indexPath.item])

    return cell
}

我花了很多时间查看不同的来源并尝试不同的东西,但是集合视图从来没有正确数量的单元格。一个想法是,它可能是因为我在自动布局中设置了单元格大小,但每当我改变它时xcode崩溃。绕过汽车布局的任何想法?或者如何更改自动布局?

谢谢!

2 个答案:

答案 0 :(得分:0)

您可以将sizeForItemAtIndexPath更改为。您可以在按照单元格数减去边距和潜水后指定单元格的大小。

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout,sizeForItemAt indexPath: IndexPath) -> CGSize {
        let size = (Int(collectionView.bounds.width) - (score1.count+1)*5) /(score1.count)  // 5 is the margin you want to keep in between 2 cells
        return CGSize(width: CGFloat(size), height: 80)
    }

如果您有任何疑问,请告诉我。我会尽力澄清。

答案 1 :(得分:0)

试试这个

extension YourViewController : UICollectionViewDelegateFlowLayout{

  func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
    let rowItems:CGFloat = 4
    let padding:CGFloat = 2
    let width = (collectionView.bounds.width / rowItems) - padding //Change width as per your requirement
    let height = collectionView.bounds.height - (2 * padding)//Change height as per your requirement
    return CGSize(width: width, height: height)
  }

}