UICollectionView分页视图被切断-分页不起作用

时间:2018-12-06 15:11:40

标签: ios pagination uicollectionview uicollectionviewcell horizontal-scrolling

我正在实现一个UICollectionView,它需要水平页面。 UICollectionViewCell必须与UICollectionView相同。该单元具有2个嵌入式行。第一个具有UITextView和UIButton,第二个具有UITextView。

UICollectionviewCell和约束可在预览中针对不同大小的iPhone(例如4s,8、8plus)工作,但是在模拟器中运行时,分页无法正常工作,并且单元格的宽度(未居中)该单元的移动距离不够远,无法到达下一个单元,从而使该单元看起来像边界。

我已经尝试过以下网址的解决方案:UICollectionView Horizontal Paging not centered

但是我似乎无法正确获得宽度和居中位置。我正在使用的代码如下。

internal class AccessViewController : UIViewController,    UICollectionViewDataSource, UICollectionViewDelegate, UICollectionViewDelegateFlowLayout {

//...

    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {

    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Cell", for: indexPath) as! PagerContentCollectionViewCell

    //Set the cell title
    cell.txtTitle.text = "title"

    //add a target for the call capability
    cell.btnCall.addTarget(self, action: #selector(didButtonClick), for: .touchUpInside)

    //description
    cell.txtDescription.text =  "description"

    return cell
} 


func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
    //let i = IndexPath(item: titles.count, section: 0)
    collectionView.scrollToItem(at: indexPath, at: .right, animated: true)
    print("Selected")
    collectionView.reloadData()
}


func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat {

    return 0
}

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
    let frameSize = collectionView.frame.size
    return CGSize(width: frameSize.width, height: frameSize.height)
}


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

    let frameSize = collectionView.frame.size
    return CGSize(width: frameSize.width, height: frameSize.height)
}

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAt section: Int) -> UIEdgeInsets {

     return UIEdgeInsets(top: 0, left: 5, bottom: 0, right: 5)
}

UICollectionView的宽度和高度分别为267、153。 UICollectioViewCell的宽度和高度262、150 部分插图为0,0,0,0。

非常感谢您的帮助。

谢谢

编辑:我在试图用于布局的代码中添加了代码。我可能也想念其他东西。

1 个答案:

答案 0 :(得分:0)

我能够使用以下两个功能进行修复:

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat {

    return 0
}

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
    let frameSize = collectionView.frame.size
    return CGSize(width: frameSize.width, height: frameSize.height)
}