设置collectionView大小。 (sizeForItemAtIndexPath函数不起作用)Swift 3

时间:2016-10-13 11:36:00

标签: ios swift uicollectionview tableview

我有一个tableView,每tableViewCellcollectionView

我正在尝试使用以下代码更改collectionView大小:

 func collectionView(_ collectionView: UICollectionView,
                    layout collectionViewLayout: UICollectionViewLayout,
                    sizeForItemAt indexPath: IndexPath) -> CGSize {

    if collectionView.tag == 2{

        return CGSize(width: 100, height: 100)

    }else if collectionView.tag == 4 {


        return CGSize(width: 222, height: 200)

    }else{


        return CGSize(width: 10, height: 10)
    }

}

问题是没有错误但是细胞不会改变大小

如果您需要了解更多信息,请撰写评论。

谢谢。

7 个答案:

答案 0 :(得分:59)

此方法的签名在Swift 3中已更改为:

func collectionView(_ collectionView: UICollectionView,
                    layout collectionViewLayout: UICollectionViewLayout,
                    sizeForItemAt indexPath: IndexPath) -> CGSize {
    // your code here
}

注意细微差别:(_ collectionView: ...而不是(collectionView: ...

这是因为在Swift 3中,您必须明确指定第一个参数的标签。您可以通过添加下划线字符_来覆盖此默认行为。

另外,请确保您的班级同时采用{​​{1}}和UICollectionViewDelegate协议

UICollectionViewDelegateFlowLayout

请参阅this link以了解有关Swift 3更改的更多信息。

答案 1 :(得分:34)

首先,请不要忘记从 UICollectionViewDelegateFlowLayout 委托进行扩展。

对于单个collectionview显示逻辑:

 func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
    let width = ((collectionView.frame.width - 15) / 2) // 15 because of paddings
    print("cell width : \(width)")
    return CGSize(width: width, height: 200)
}

情节提要中的重点不要忘了估计大小:无

estimate_size_none

答案 2 :(得分:17)

您需要指定在类声明中实现协议UICollectionViewDelegateFlowLayout。

class PhrasesCompactCollectionViewController: UICollectionViewController, UICollectionViewDelegateFlowLayout

答案 3 :(得分:3)

短版

尝试添加

collectionView.delegate = dataSource

更长的版本

对我而言,这是一个小错误 -

collectionView.dataSource = self

这会调用这些方法

func numberOfSections(in collectionView: UICollectionView) -> Int
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell

但是调用

func collectionView(_ collectionView: UICollectionView,
                    layout collectionViewLayout: UICollectionViewLayout,
                    sizeForItemAt indexPath: IndexPath) -> CGSize

因为这不是UICollectionView的dataSource的一部分。它是UICollectionView委托的一部分。

所以添加以下内容解决了我的问题。

collectionView.delegate = dataSource

答案 4 :(得分:2)

所以这是我现在的代码,它有效:

        collectionView.delegate = dataSourceDelegate
        collectionView.dataSource = dataSourceDelegate
        collectionView.tag = row
        collectionView.setContentOffset(collectionView.contentOffset, animated:false)
        collectionView.reloadData()
        collectionView.register(UINib(nibName: "eventsCollectionViewCell", bundle: nil), forCellWithReuseIdentifier: "eventsCollectionViewCell")


        if row == 2{


            let layout: UICollectionViewFlowLayout = UICollectionViewFlowLayout()
            layout.sectionInset = UIEdgeInsets(top: 0, left: 0, bottom: 0, right: 0)
            layout.itemSize = CGSize(width: 120, height: 120)
            layout.scrollDirection = .horizontal

            collectionView.collectionViewLayout = layout

        }else if row == 4 {


            let layout: UICollectionViewFlowLayout = UICollectionViewFlowLayout()
            layout.sectionInset = UIEdgeInsets(top: 0, left: 0, bottom: 0, right: 0)
            layout.itemSize = CGSize(width: 222, height: 200)
            layout.scrollDirection = .horizontal

            collectionView.collectionViewLayout = layout

        }else{

            print("else")
        }

答案 5 :(得分:0)

我遇到了同样的问题!如果您将大小设置为宽度的一半(宽度/ 2),那么它仍将显示为整个宽度,因为填充被添加到宽度/ 2。

修复:确保将Storyboard中的section insets设置为0.或者,将width / 2调整为包含section insets的大小。

我花了一段时间修复那个; - )

答案 6 :(得分:0)

不要忘记将 UICollectionViewFlowLayout 对象分配给您的 collectionViewLayout 对象,因为UICollectionView默认使用UICollectionViewLayout(而不是UICollectionView Flow Layout)。

  

let flowLayout = UICollectionViewFlowLayout()

     

collectionView.collectionViewLayout = flowLayout