一些简单的对layout的布局
- (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect {
// 获取所有的item布局
NSMutableArray * attributes = [[super layoutAttributesForElementsInRect:rect] mutableCopy];
// 设置的最大间距,根据需要修改
CGFloat maximumSpacing = 5.0;
if (attributes.count > 0) {
UICollectionViewLayoutAttributes *firstAttributes = attributes[0];
CGRect frame = firstAttributes.frame;
frame.origin.x = maximumSpacing;
firstAttributes.frame = frame;
}
// 从第二个循环到最后一个
for (NSInteger i = 1 ; i < attributes.count ; i++ ) {
// 当前的attribute
UICollectionViewLayoutAttributes * currentLayoutAttributes = attributes[i];
// 上一个attribute
UICollectionViewLayoutAttributes * prevLayoutAttributes = attributes[i - 1];
// 前一个cell的最右边
CGFloat origin = CGRectGetMaxX(prevLayoutAttributes.frame);
// 如果当前一个cell的最右边加上我们的想要的间距加上当前cell的宽度依然在contentSize中,我们改变当前cell的原点位置
// 不加这个判断的后果是,UICollectionView只显示一行,原因是下面所有的cell的x值都被加到第一行最后一个元素的后面了
if (origin + maximumSpacing + currentLayoutAttributes.frame.size.width < self.collectionViewContentSize.width - 20) {
if (currentLayoutAttributes.indexPath.row == 0) {
CGRect frame = currentLayoutAttributes.frame;
frame.origin.x = maximumSpacing;
currentLayoutAttributes.frame = frame;
} else {
CGRect frame = currentLayoutAttributes.frame;
frame.origin.x = origin + maximumSpacing;
currentLayoutAttributes.frame = frame;
}
} else {
CGRect frame = currentLayoutAttributes.frame;
frame.origin.x = maximumSpacing;
currentLayoutAttributes.frame = frame;
}
}
return attributes;
}
使用很简单 ,创建一个继承与UICollectionViewFlowLayout的类,写上就OK