菜鸟教程小白 发表于 2022-12-11 19:36:39

ios - 滚动UICollectionView时如何自定义顶部屏幕上的标题 View ?


                                            <p><p>我的 <code>UICollectionView</code> 中有标题(标题:<code>UICollectionReusableView</code>)。 header 有 3 个 UIView(<code>UIView1</code>、<code>UIView2</code>、<code>UIView3</code>)。当我设置 <code>collectionLayout.sectionHeadersPinToVisibleBounds = true</code> 时,当我滚动集合时标题将位于顶部。我希望当标题贴在 <code>UICollectionView</code> 顶部时,我将隐藏 <code>UIView1</code> 和 <code>UIView2</code>。我怎样才能做到这一点? </p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p><code>UICollectionView</code> 是 <code>UIScrollView</code> 的子类。这意味着如果您为其分配了一个委托(delegate),那么该委托(delegate)可能会监听 <code>scrollViewDidScroll(_ scrollView: UIScrollView)</code> 方法,该方法将在每次 Collection View 中的偏移量发生变化时被调用。</p>

<p>在此事件中,您需要获取所有标题 View ,我假设您可以通过在 Collection View 上调用 <code>visibleSupplementaryViews</code> 并检查其类类型来获取这些 View 。</p>

<p>如果收到的 View 确实是您的标题,您将需要检查其框架与您的 Collection View 相比,并查看其位置是否在顶部。为此,您可以将框架转换为您的坐标:</p>

<pre><code>func isHeader(headerView: UIView, onTopOfCollectionView collectionView: UICollectionView) -&gt; Bool {
    guard let collectionSuperView = collectionView.superview else {
         return false // Collection view is not in view hierarchy. This will most likely never happen
    }
    let convertedFrame = headerView.convert(headerView.bounds, to: collectionSuperView) // Convert frame of the view to whatever is the superview of collection view
    return convertedFrame.origin.y &lt;= collectionView.frame.origin.y // Compare frame origins
}
</code></pre>

<p>所以我猜整个事情会是这样的:</p>

<pre><code>func scrollViewDidScroll(_ scrollView: UIScrollView) {
    collectionView.visibleSupplementaryViews(&lt;#My identifier here#&gt;).forEach { view in
      if let header = view as? MyHeaderView {
            header.hideSecondaryViews = isHeader(headerView: header, onTopOfCollectionView: collectionView)
      }
    }
}
</code></pre>

<p>我希望这能让你走上正轨。</p></p>
                                   
                                                <p style="font-size: 20px;">关于ios - 滚动UICollectionView时如何自定义顶部屏幕上的标题 View ?,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/48276662/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/48276662/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: ios - 滚动UICollectionView时如何自定义顶部屏幕上的标题 View ?