iOS 11 下 UICollectionView 的HeaderView 遮擋滾動條

這個問題在之前的 iOS 10 上是沒有的,iOS 11 新出之後纔出現。在使用了- collectionView: viewForSupplementaryElementOfKind: atIndexPath:的 UICollectionView 頁面中,滑動頁面的時候滾動條會被 HeaderView 遮擋.

修改前的樣子:

//
//  CustomCollectionReusableView.m
//  EMall
//
//  Created by YJHou on 2017/9/16.
//  Copyright © 2017年 stackhou . All rights reserved.
//

#import "CustomCollectionReusableView.h"

@interface CustomCollectionReusableView ()

@property (nonatomic, strong) UILabel *showLabel; /**< 顯示控件 */

@end

@implementation CustomCollectionReusableView

- (void)layoutSubviews {
    [super layoutSubviews];
    [self _setUpSubViews];
}

- (void)_setUpSubViews {
    [self addSubview:self.showLabel];
}

#pragma mark - Lazy
- (UILabel *)showLabel{    
    if (!_showLabel) {
        _showLabel = [[UILabel alloc] initWithFrame:CGRectMake(20, 20, 120, self.frame.size.height)];
        _showLabel.font = [UIFont systemFontOfSize:13];
        _showLabel.textAlignment = NSTextAlignmentLeft;
        _showLabel.backgroundColor = [UIColor clearColor];
        _showLabel.textColor = [UIColor redColor];
    }
    return _showLabel;
}

@end

修復完成後

//
//  CustomCollectionReusableView.m
//  EMall
//
//  Created by YJHou on 2017/9/16.
//  Copyright © 2017年 stackhou . All rights reserved.
//

#import "CustomCollectionReusableView.h"

#ifdef __IPHONE_11_0
@interface CustomLayer : CALayer

@end
#endif

@interface CustomCollectionReusableView ()

@property (nonatomic, strong) UILabel *showLabel; /**< 顯示控件 */

@end

#ifdef __IPHONE_11_0
@implementation CustomLayer

- (CGFloat) zPosition {
    return 0;
}

@end
#endif

@implementation CustomCollectionReusableView

- (void)layoutSubviews {
    [super layoutSubviews];
    [self _setUpSubViews];
}

- (void)_setUpSubViews {
    [self addSubview:self.showLabel];
}

#pragma mark - Lazy
- (UILabel *)showLabel{    
    if (!_showLabel) {
        _showLabel = [[UILabel alloc] initWithFrame:CGRectMake(20, 20, 120, self.frame.size.height)];
        _showLabel.font = [UIFont systemFontOfSize:13];
        _showLabel.textAlignment = NSTextAlignmentLeft;
        _showLabel.backgroundColor = [UIColor clearColor];
        _showLabel.textColor = [UIColor redColor];
    }
    return _showLabel;
}

#ifdef __IPHONE_11_0
+ (Class)layerClass {
    return [CustomLayer class];
}
#endif

@end
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章