标签:
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的一个小总结,针对自己容易忘记的整理,如有理解错误的地方,还请路过的大神指点下小白,不胜感激
UIcollectionView使用浅析
标签:
原文地址:http://www.cnblogs.com/mamadou/p/5801355.html