纯代码实现UICollectionView头部

1、创建CollectionView

-(void)createColloctionView
{
    UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc]init];
    layout.sectionInset = UIEdgeInsetsMake(10, 20, 10, 20);
    
    layout.headerReferenceSize = CGSizeMake(kScreenSize.width, 210); //设置头部高度
    
    self.collectionView = [[UICollectionView alloc]initWithFrame:CGRectMake(0, kNavigationBar, kScreenSize.width, kScreenSize.height-kNavigationBar) collectionViewLayout:layout];
    
    self.collectionView.backgroundColor = [UIColor whiteColor];
    
    self.collectionView.delegate = self;
    self.collectionView.dataSource = self;
    
    [self.view addSubview:self.collectionView];
    
    [self.collectionView registerNib:[UINib nibWithNibName:kSubjectCollectionViewCell bundle:nil] forCellWithReuseIdentifier:kSubjectCollectionViewCell];
    
    //注册头部
    [self.collectionView registerClass:[UICollectionReusableView class] forSupplementaryViewOfKind:UICollectionElementKindSectionHeader withReuseIdentifier:@"UICollectionReusableView"];
}

2、实现协议方法

//collectionView 头部
-(UICollectionReusableView *)collectionView:(UICollectionView *)collectionView viewForSupplementaryElementOfKind:(NSString *)kind atIndexPath:(NSIndexPath *)indexPath
{
    NSString *str = @"UICollectionReusableView";
    
    UICollectionReusableView *reusableView = nil;
    
    //判断类别
    if (kind == UICollectionElementKindSectionHeader) {
        reusableView = [collectionView dequeueReusableSupplementaryViewOfKind:UICollectionElementKindSectionHeader withReuseIdentifier:str forIndexPath:indexPath];
        
        
        UIImageView *imageView = [[UIImageView alloc]initWithFrame:reusableView.bounds];
        
        [imageView sd_setImageWithURL:[NSURL URLWithString:self.subjectModel.news.newsimg] placeholderImage:[UIImage imageNamed: @"News"]];
        
        UILabel *titleLabel = [[UILabel alloc]initWithFrame:CGRectMake(0, CGRectGetHeight(imageView.frame)-20, kScreenSize.width, 20)];
        titleLabel.backgroundColor = [UIColor colorWithRed:196/255.0 green:196/255.0 blue:196/255.0 alpha:0.8];
        NewsDataModel *newsDataModel = self.subjectModel.news_data.lastObject;
        titleLabel.text = [NSString stringWithFormat:@"    %@", newsDataModel.subject_part_name];
        titleLabel.font = [UIFont systemFontOfSize:13];
        titleLabel.textColor = [UIColor whiteColor];
        [imageView addSubview:titleLabel];

        [reusableView addSubview:imageView];
    }
    
    return reusableView;
}




转载于:https://my.oschina.net/u/2430056/blog/487800

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一些关于UICollectionView基本使用的代码示例,您可以参考以下代码: //1.创建UICollectionView,指定layout UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc]init]; UICollectionView *collectionView = [[UICollectionView alloc]initWithFrame:CGRectZero collectionViewLayout:layout]; //2.注册UICollectionViewCell [collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:@"cellIdentifier"]; //3.实现UICollectionViewDataSource协议方法 - (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section{ return dataArray.count; } - (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath{ UICollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"cellIdentifier" forIndexPath:indexPath]; //设置cell内容 return cell; } //4.设置UICollectionViewDelegateFlowLayout方法,指定cell size等布局属性 - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath{ return CGSizeMake(100, 100); } - (UIEdgeInsets)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout insetForSectionAtIndex:(NSInteger)section{ return UIEdgeInsetsMake(10, 10, 10, 10); } //5.添加UICollectionView到视图中 [self.view addSubview:collectionView]; 以上只是示例代码,具体还需根据您的需求来实现。希望对您有帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值