UIcollectionView使用浅析

uicollectionview最大的特点就是它的数据源方法(cell for indexpath)里只需要从缓存池中重用即可,即调用deque...for indexPath..(这里有个坑,注意tableview里重用时并不需要后面红色的indexpath部分,如果你在tableview里用这个方法,就自己给自己找麻烦,要在viewdidiload里注册一个,和collection view类似),
     然后你肯定要有一个初始化cell的,这时变化就来了,它的初始化部分写在了viewdidload里面,而加载cell我们了解的有三种方式:SB、xib、纯代码。
     这里同样对应的有三种方式。首先说SB,这个相对简单,只需要在SB的cell里identifier写上标识就可以了,不用自己去创建
     然后说说xib。xib里你需要注册xib,代码例子如下
    // 加载xib文件"当前还没有实例化"
    UINib *nib = [UINib nibWithNibName:@"HMAppCell" bundle:nil];
    // 让nib"xib"文件激活
   HMAppCell *cell = [[nib instantiateWithOwner:nil options:nil] lastObject];
// 用xib文件来注册cell并且绑定重用标识""
    // 如果用了注册机制xib中的cell最好不要再设置重用标识了
    [self.collectionView registerNib:nib forCellWithReuseIdentifier:ID];
 
   再是纯代码,相对来说有点麻烦
     先把viewcontroller里面viewdidload里的注册部分代码列出来,再数数里面的坑
 // 创建流布局"它里面有控制cell大小的属性,而且cell的默认尺寸50,50"
    UICollectionViewFlowLayout *flowLayout = [[UICollectionViewFlowLayout alloc] init];
    // 当cell的尺寸为0,0时返回cell的数据源方法不会调用
//    flowLayout.itemSize = CGSizeZero;
    // 设置cell的尺寸
    flowLayout.itemSize = CGSizeMake(100, 120);
    flowLayout.sectionInset = UIEdgeInsetsMake(10, 10, 0, 10);
    // 1.创建collectionView
    UICollectionView *collectionView = [[UICollectionView alloc] initWithFrame:self.view.bounds collectionViewLayout:flowLayout];
    // 设置背景颜色
    collectionView.backgroundColor = [UIColor whiteColor];
    // 添加到父控件上
    [self.view addSubview:collectionView];
   
    // 设置数据源
    collectionView.dataSource = self;
   
    // 通过一个类来注册cell并绑定重用标识
    // 如果通过class来注册的cell 如果它要创建cell了它会调用注册时指定类的init初始
    [collectionView registerClass:[HMAppCell class] forCellWithReuseIdentifier:ID];
可以看到 ---------1>需要自己创建一个布局类型,一般都是选择flowlayout类型,因为你是纯代码创建的,而前面两种都是直接从sb里面拉出来的属性。  2>在cell的类里怎么添加子控件这里也有一个坑,添加控件的代码必须重写initWithFrame方法中,而布局子控件要在layoutsubviews中,不能全部一股脑创建的时候设置frame。 这里和tableviewcell里的有点不一样,tableviewcell里的创建子控件是写在 - (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier方法中,设置frame可以视情况而定(有事frame是由里面的内容来决定的,而每个cell的内容又不一样,所以可能也写在数据模型的set方法里,这种思维在collection里感觉也是适用的)。
 
最后再说说collection里面的一个重要东西.layout布局。一般我们选择flowlayout流式布局就足够了,它是每行cell的高度都一样的。但也有特殊情况,像瀑布流,这时候就要另当别论了,需要重写layout的里面的方法,去定义自己需要的布局方式。这里主要说一下flowlayout里面的一些属性: minimumLineSpacing,行间距,系统默认是10,我们可以自己去重新设置。 minimumInteritemSpacing,item之间的间距,这个就有点意思了,系统也给了一个默认值10,但我们一般看到实际的效果并不是10,为什么呢?因为item的间距还和item的宽度有关,当你给定了宽度后(若是没有给定,系统默认为50),系统会根据item的宽度和你设置的间距来自动计算item的个数,个数确定了后自动调整item的间距,所以我们一般见到item的宽度不是自己设定的那个值
 
PS>>>以上只是自己对于collectionview的一个小总结,针对自己容易忘记的整理,如有理解错误的地方,还请路过的大神指点下小白,不胜感激
posted @ 2016-08-24 00:29  麻麻豆  阅读(478)  评论(0编辑  收藏  举报