1

我有一个 UICollectionView 填充了从一个日期到另一个日期的日期。我已经用 IGListKit 实现了 UICollectionView。我想在每个单元格上启用分页,以便每个单元格在滚动经过它时都会落在圆圈的中间。(如下所示)我尝试了几种分页方式,但这些方式并不直接位于圆圈的中间(如第二张图片所示)。发生的事情是,单元格被分页到左侧,我希望有一个 20 的插图,以便它适合圆圈

在此处输入图像描述 在此处输入图像描述

为了使当前日期在视图首次加载时显示在圆圈的左侧,我将语义设置为Force Right-to-Left,并且我还设置了 edgeInsets,它们是:

left: screenWidth-62, right: 20)

单元格的宽度为 42,侧面的插图为 20,因此第一个单元格将位于带有这些插图的圆圈中。因此,当视图首次加载时,集合视图如下所示:

在此处输入图像描述

我基本上希望每个单元格在滚动过去时都落在这个圆圈内(如果滚动停止)

这是我到目前为止所拥有的:

func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {
    if scrollView == self.collectionView {
        var currentCellOffset = self.collectionView.contentOffset
        currentCellOffset.x += (self.collectionView.frame.width / 2) + 20
        if let indexPath = self.collectionView.indexPathForItem(at: currentCellOffset) {
            self.collectionView.scrollToItem(at: indexPath, at: .centeredHorizontally, animated: true)
        }
    }
}

和这个:

collectionView.decelerationRate = UIScrollView.DecelerationRate.fast

有谁知道如何解决这个问题?

谢谢

4

1 回答 1

1

我创建了一个自定义集合视图布局,用于按单元格而不是屏幕分页

我还通过自述文件中的示例概述了几种不同的自定义方法

这里查看

如果您对此有任何疑问或需要更多帮助,请告诉我

于 2019-08-19T19:12:43.317 回答