UICollectionView 标头未显示

Posted

技术标签:

【中文标题】UICollectionView 标头未显示【英文标题】:UICollectionView header not showing 【发布时间】:2012-10-03 00:40:46 【问题描述】:

我正在开展一个项目,该项目使用UICollectionView 来显示几张专辑。这些项目显示正常,但现在我想在第一部分上方显示一个标题。

为此,我将registerNib:forSupplementaryViewOfKind:withReuseIdentifier: 添加到我的init 方法中。像这样:

[self.collectionView registerNib:[UINib nibWithNibName:@"AlbumHeader" bundle:nil] forSupplementaryViewOfKind:UICollectionElementKindSectionHeader withReuseIdentifier:kAlbumHeaderIdentifier];

AlbumHeader Nib 包含AlbumHeader 类的视图,它是UICollectionView 的子类。)

之后,我实现了collectionView:viewForSupplementaryElementOfKind:atIndexPath方法:

- (UICollectionReusableView *)collectionView:(UICollectionView *)collectionView viewForSupplementaryElementOfKind:(NSString *)kind atIndexPath:(NSIndexPath *)indexPath 
    return [collectionView dequeueReusableSupplementaryViewOfKind:kind withReuseIdentifier:kAlbumHeaderIdentifier forIndexPath:indexPath];

我想现在它应该尝试加载标题视图。但它没有,补充视图的方法没有被调用。

我错过了什么?坚持了几个小时,多次阅读UICollectionViews 上的文档,但似乎没有任何帮助。有什么想法吗?

【问题讨论】:

【参考方案1】:

在寻找 yuf 询问的方法后,我读到默认情况下页眉/页脚的大小为 0,0。如果 size 为 0,则不显示页眉/页脚。

您可以使用属性设置大小:

flowLayout.headerReferenceSize = CGSizeMake(0, 100);

然后所有标题将具有相同的大小。如果每个部分必须不同,您可以实现以下方法,它是UICollectionViewDelegateFlowLayout 协议的一部分。

- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForHeaderInSection:(NSInteger)section 
    if (section == albumSection) 
        return CGSizeMake(0, 100);
    

    return CGSizeZero;

请注意,在垂直滚动中它使用返回的height 和集合视图的完整宽度,在水平滚动中它使用返回的width 和集合视图的完整高度。

【讨论】:

对于仍然遇到此问题的任何人,为了让我完成这项工作,我还必须为“collectionview.footerReferenceSize”指定一个大小。不确定该请求是否特定于 ios 7... 这是一个令人难以置信的提示。谢谢一百万,Guido! 享受赏金吧! :) @JoeBlow 谢谢,感激! 不是给定一个 100px 的高度,是否可以找到集合标题视图的实际高度并将其返回?【参考方案2】:

你实现了吗:

- (UICollectionViewLayoutAttributes *)layoutAttributesForSupplementaryElementOfKind:(NSString *)kind atIndexPath:(NSIndexPath *)indexPath

为了让一件事发挥作用,有很多方法可以实现……我也在学习。告诉我它是否有效。

编辑:抱歉错误的方法。那是我认为的子类化。我说的是UICollectionViewLayout(如果您的布局支持补充视图,则为您子类化的布局对象):

- layoutAttributesForSupplementaryViewOfKind:atIndexPath:

请看这里:https://developer.apple.com/library/ios/#documentation/UIKit/Reference/UICollectionViewLayout_class/Reference/Reference.html#//apple_ref/occ/cl/UICollectionViewLayout

【讨论】:

该方法似乎不是任何委托的一部分? @GuidoH 您使用的是 FlowLayout 还是您的自定义布局?这个答案是指自定义布局。 我确实使用了流式布局。接受的答案解决了这一切,也很有意义。 =)【参考方案3】:

适用于 SWIFT 3 和 SWIFT 4

    self.collectionView.register(UINib(nibName: "SectionCollectionReusableView", bundle: nil), forSupplementaryViewOfKind: UICollectionElementKindSectionHeader, withReuseIdentifier: "SectionCollectionReusableView")



    self.collectionView.fs_width = self.collectionView.bounds.width

    let layout: UICollectionViewFlowLayout = UICollectionViewFlowLayout()
    layout.sectionInset = UIEdgeInsets(top: 70, left: 40, bottom: 0, right: 0)
    layout.minimumInteritemSpacing = 0
    layout.minimumLineSpacing = 0
    layout.estimatedItemSize = CGSize(width: 350, height: 140)
    layout.scrollDirection = .horizontal
    layout.headerReferenceSize = CGSize(width: self.collectionView.bounds.size.width, height: 60)
    layout.sectionHeadersPinToVisibleBounds = true
    self.collectionView!.collectionViewLayout = layout

您必须将此添加到 ViewDidLoad,并注意

layout.headerReferenceSize = CGSize(width: self.collectionView.bounds.size.width, height: 60)

这将使标题部分布局

感谢@Guido Hendriks,我也从他们的回答中得到了启示

【讨论】:

以上是关于UICollectionView 标头未显示的主要内容,如果未能解决你的问题,请参考以下文章

UICollectionView标头未显示

在 UICollectionView 中使用 reloadData 时如何从重新加载中排除标头

UICollectionView,按钮未出现

未显示自定义 UICollectionReusableView 元素

向浮动 UICollectionView 标头添加阴影

UICollectionView 水平分页仅在第一页上每行显示 3 个单元格