.hatom
#import <UIKit/UIKit.h> @interface JHCollectionViewFlowLayout : UICollectionViewFlowLayout ///一頁展現行數 @property (nonatomic, assign) NSInteger row; ///一頁展現列數 @property (nonatomic, assign) NSInteger column; ///行間距 @property (nonatomic, assign) CGFloat rowSpacing; ///列間距 @property (nonatomic, assign) CGFloat columnSpacing; ///item大小 @property (nonatomic, assign) CGSize size; ///一頁的寬度 @property (nonatomic, assign) CGFloat pageWidth; @end
.mspa
#import "JHCollectionViewFlowLayout.h" @interface JHCollectionViewFlowLayout() @property (strong, nonatomic) NSMutableArray *attributesArray; @end @implementation JHCollectionViewFlowLayout - (void)prepareLayout { [super prepareLayout]; _attributesArray = @[].mutableCopy; if (_pageWidth == 0) { _pageWidth = [UIScreen mainScreen].bounds.size.width; } self.itemSize = self.size; self.minimumLineSpacing = self.rowSpacing; self.minimumInteritemSpacing = self.columnSpacing; NSUInteger count = [self.collectionView numberOfItemsInSection:0]; for (NSUInteger i = 0; i<count; i++) { NSIndexPath *indexPath = [NSIndexPath indexPathForItem:i inSection:0]; UICollectionViewLayoutAttributes *attributes = [self layoutAttributesForItemAtIndexPath:indexPath]; [_attributesArray addObject:attributes]; } } //計算每一個item的frame - (UICollectionViewLayoutAttributes *)layoutAttributesForItemAtIndexPath:(NSIndexPath *)indexPath{ UICollectionViewLayoutAttributes *attribute = [UICollectionViewLayoutAttributes layoutAttributesForCellWithIndexPath:indexPath]; NSInteger index = indexPath.item; NSInteger page = index / (_row * _column); // % 運算 肯定 x 是 0,1,2 ... _column-1 CGFloat x = index % _column * (_size.width + _columnSpacing) + page * _pageWidth; // / 運算 肯定 y 是 在哪行(一行有 column 個), % 肯定在 0,1,2 ... _row-1 行內的哪行 CGFloat y = (index / _column % _row) * (_size.height + _rowSpacing); attribute.frame = CGRectMake(x, y, _size.width, _size.height); return attribute; } //返回全部item的frame - (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect{ return _attributesArray; } //返回總的可見尺寸 //避免一頁未排滿,滑動顯示不全 - (CGSize)collectionViewContentSize{ int width = (int)ceil(_attributesArray.count/(_row * _column * 1.0)) * _pageWidth; return CGSizeMake(width, 0); } @end