iOS 解决UICollectionView 计算 Cell 大小的问题
前言
API不熟悉导致的问题,想当然的去理解果然会出问题,这里记录一下UICollectionView使用问题。
正文
陷阱一:minimumLineSpacing、minimumInteritemSpacing
很容易就把这两个属性设置为0,这两个属性是最小行间距和最小列间距,注意是最小!!也就是说实际上可以>0,并不是间距就是0
陷阱二:sectionInset
设置cell的边距。一开始我以为是每一个cell的边距,相邻之间会叠加效果,实际上并不是这样的,这个属性只是保证相邻之间的间距,并不叠加!!
理解了上面两个陷阱,我们就可以精确计算Cell的大小了,再来设置itemSize的大小才会正确。例如:
letITEM_MIN_WIDTH:CGFloat=300
letITEM_SPACING:CGFloat=6
funcresizeCollectionView(size:CGSize){
ifletlayout=collectionView?.collectionViewLayoutas?UICollectionViewFlowLayout{
layout.minimumLineSpacing=ITEM_SPACING
layout.minimumInteritemSpacing=ITEM_SPACING
varitemCount=Int(size.width/ITEM_MIN_WIDTH)
ifitemCount==0{
itemCount=1
}
ifitemCount==1{
layout.itemSize=CGSizeMake(size.width,size.width*10/16)
layout.sectionInset=UIEdgeInsetsMake(6,0,0,0)
}else{
letwidth=(size.width-CGFloat((itemCount+1))*ITEM_SPACING)/CGFloat(itemCount)
layout.itemSize=CGSizeMake(width,width*10/16)
layout.sectionInset=UIEdgeInsetsMake(ITEM_SPACING,ITEM_SPACING,0,ITEM_SPACING)
}
collectionView?.layoutIfNeeded()
}
}
代码说明:
传入当前view的size,动态计算cell大小,可以方便的适配iPhone/iPad,单列时隐藏两边边距,多列时显示两边间隙。
以上就是对IOSUICollectionView用法和说明,希望能帮助 IOS开发的朋友。
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志