使用自定义UICollectionViewLayout的UICollectionViewCell在一个子视图上创建Parallax Animation

问题描述 投票:1回答:1

灵感来自本教程[带视差的自定义UICollectionViewLayout教程] [1]

[1]:https://www.raywenderlich.com/527-custom-uicollectionviewlayout-tutorial-with-parallax我创建了自己的视差集合视图版本。

我正在使用以下逻辑创建视差动画和弹跳对页眉和页脚的影响:

 private func updateSupplementaryViews(_ type: Element, attributes: CustomLayoutAttributes, collectionView: UICollectionView, indexPath: IndexPath) {
    if type == .header,
        settings.isHeaderStretchy {

        var delta: CGFloat = 0.0
        let updatedHeight = min(
            collectionView.frame.height + headerSize.height,
            max(headerSize.height , headerSize.height - contentOffset.y))

        let scaleFactor = updatedHeight / headerSize.height

        if contentOffset.y <= 0{
            delta = (updatedHeight - headerSize.height) / 2

        }else{
            delta = (headerSize.height - updatedHeight - abs(contentOffset.y))
        }

        let scale = CGAffineTransform(scaleX: scaleFactor, y: scaleFactor)
        let translation = CGAffineTransform(translationX: 0, y: min(contentOffset.y, headerSize.height) + delta)
        attributes.transform = scale.concatenating(translation)

    }else if type == .footer,
        settings.isFooterStretchy {

        var updatedHeight: CGFloat = 0.0
        if collectionView.contentSize.height - contentOffset.y < UIScreen.main.bounds.height {
            updatedHeight = min(
                collectionView.frame.height + footerSize.height,
                max(footerSize.height, abs(((collectionView.contentSize.height - (footerSize.width + deviationDeviceSize)) - UIScreen.main.bounds.height) - contentOffset.y)))
        }else{
            updatedHeight = min(
                collectionView.frame.height + footerSize.height,
                max(headerSize.height, headerSize.height - contentOffset.y))
        }

        let scaleFactor = updatedHeight / footerSize.height
        let delta = ((updatedHeight - footerSize.height) / 2) - footerSize.height
        let scale = CGAffineTransform(scaleX: scaleFactor, y: scaleFactor)
        let translation = CGAffineTransform(translationX: 0, y: min(contentOffset.y, footerSize.height) + delta )
        attributes.transform = scale.concatenating(translation)
    }
}

除了令人烦恼的事实之外,一切都很有效,我的所有单元子视图都是用这个动画缩放的,我只想缩放我的背景图像。这似乎很简单但不幸的是我无法找到一种方法来控制转换操纵哪些子视图。

ios swift uicollectionview uicollectionviewcell uicollectionviewlayout
1个回答
0
投票
  1. 你为Element.footer设置了什么customAttributes?
  2. 你设置的footerSize是什么?

您在项目中包含了一些在页脚中实现的实现,这对我们来说是不可见的?介意分享整个文件?

© www.soinside.com 2019 - 2024. All rights reserved.