当我在没有自定义布局对象的情况下实现UICollectionView时,会出现所有16个可重用单元格。也就是说,我在该部分中有1个部分包含16个项目。创建自定义布局对象时,只显示一个单元格。如果我将部分#更改为5,则会出现5个单元格。为什么collectionView在使用布局对象时绘制节,在使用默认网格时绘制项?我错过了什么吗?
我在这里继承了UICollectionViewLayout:
static NSString * const kPadLayoutType = @"gridPads";
- (id)initWithCoder:(NSCoder *)aDecoder
{
self = [super initWithCoder:aDecoder];
if(self) {
[self setup];
}
return self;
}
- (void)setup
{
self.itemInsets = UIEdgeInsetsMake(22.0f, 22.0f, 13.0f, 22.0f);
self.itemSize = CGSizeMake(125.0f, 125.0f);
self.interItemSpacingY = 12.0f;
self.numberOfColumns = 4;
}
# pragma mark _____Layout
- (void)prepareLayout
{
NSMutableDictionary *newLayoutInfo = [NSMutableDictionary dictionary];
NSMutableDictionary *cellLayoutInfo = [NSMutableDictionary dictionary];
NSInteger sectionCount = [self.collectionView numberOfSections];
NSIndexPath *indexPath = [NSIndexPath indexPathForItem:0 inSection:0];
for(NSInteger section = 0; section < sectionCount; section++) {
NSInteger itemCount = [self.collectionView numberOfItemsInSection:section];
for(NSInteger item = 0; item < itemCount; item++) {
indexPath = [NSIndexPath indexPathForItem:item inSection:section];
UICollectionViewLayoutAttributes *itemAttributes = [UICollectionViewLayoutAttributes layoutAttributesForCellWithIndexPath:indexPath];
itemAttributes.frame = [self frameForPadAtIndexPath:indexPath];
cellLayoutInfo[indexPath] = itemAttributes;
}
}
newLayoutInfo[kPadLayoutType] = cellLayoutInfo;
self.layoutInfo = newLayoutInfo;
}
- (CGSize)collectionViewContentSize
{
return self.collectionView.frame.size;
}
- (NSArray *) layoutAttributesForElementsInRect:(CGRect)rect
{
NSMutableArray *allAttributes = [NSMutableArray arrayWithCapacity:self.layoutInfo.count];
[self.layoutInfo enumerateKeysAndObjectsUsingBlock:^(NSString *elementIdentifier,
NSDictionary *elementsInfo,
BOOL *stop) {
[elementsInfo enumerateKeysAndObjectsUsingBlock:^(NSIndexPath *indexPath,
UICollectionViewLayoutAttributes *attributes,
BOOL *innerStop) {
if(CGRectIntersectsRect(rect, attributes.frame)) {
[allAttributes addObject:attributes];
}
}];
}];
return allAttributes;
}
- (UICollectionViewLayoutAttributes *)layoutAttributesForItemAtIndexPath:(NSIndexPath *)indexPath
{
return self.layoutInfo[kPadLayoutType][indexPath];
}
# pragma mark _____Private
- (CGRect)frameForPadAtIndexPath:(NSIndexPath *)indexPath
{
NSInteger row = indexPath.section/ self.numberOfColumns;
NSInteger column = indexPath.section % self.numberOfColumns;
CGFloat spacingX = self.collectionView.bounds.size.width - self.itemInsets.left - self.itemInsets.right - (self.numberOfColumns * self.itemSize.width);
if(self.numberOfColumns > 1) spacingX = spacingX / (self.numberOfColumns - 1);
CGFloat originX = floorf(self.itemInsets.left + (self.itemSize.width + spacingX) * column);
CGFloat originY = floor(self.itemInsets.top + (self.itemSize.height + self.interItemSpacingY) * row);
return CGRectMake(originX, originY, self.itemSize.width, self.itemSize.height);
}
我使每个setter中的布局无效。
我在UIViewController中使用了collectionView 在viewController中,我注册了我的Cell类,以便在viewDidLoad中使用并设置以下内容:
# pragma mark - UICollectionViewDataSource
- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section
{
return 16;
}
- (NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView
{
return 1;
}
- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath
{
Pad *myPad = [collectionView dequeueReusableCellWithReuseIdentifier:kPadLayoutType forIndexPath:indexPath];
return myPad;
}
答案 0 :(得分:1)
在我看来,您的frameForPadAtIndexPath:
方法会为同一部分中的每个项目返回相同的框架,并且只会改变部分的位置。
更改
NSInteger row = indexPath.section/ self.numberOfColumns;
NSInteger column = indexPath.section % self.numberOfColumns;
到
NSInteger row = indexPath.item/ self.numberOfColumns;
NSInteger column = indexPath.item % self.numberOfColumns;
可能会给你更好的结果。